mirror of
https://github.com/Cockatrice/Cockatrice.git
synced 2026-06-26 00:23:55 -07:00
Merge 4f457d9543 into 80426d77bc
This commit is contained in:
commit
ff4f92f474
4 changed files with 27 additions and 0 deletions
|
|
@ -673,8 +673,22 @@ void Servatrice::statusUpdate()
|
|||
}
|
||||
}
|
||||
|
||||
SessionEvent *Servatrice::getLoginSessionEvent() const
|
||||
{
|
||||
// Notify newly logged-in users of a pending server shutdown
|
||||
QMutexLocker locker(&shutdownStateMutex);
|
||||
if (shutdownTimer && shutdownMinutes > 0) {
|
||||
Event_ServerShutdown event;
|
||||
event.set_reason(shutdownReason.toStdString());
|
||||
event.set_minutes(static_cast<google::protobuf::uint32>(shutdownMinutes));
|
||||
return Server_ProtocolHandler::prepareSessionEvent(event);
|
||||
}
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
void Servatrice::scheduleShutdown(const QString &reason, int minutes)
|
||||
{
|
||||
shutdownStateMutex.lock();
|
||||
shutdownReason = reason;
|
||||
shutdownMinutes = minutes;
|
||||
nextShutdownMessageMinutes = shutdownMinutes;
|
||||
|
|
@ -683,6 +697,7 @@ void Servatrice::scheduleShutdown(const QString &reason, int minutes)
|
|||
connect(shutdownTimer, SIGNAL(timeout()), this, SLOT(shutdownTimeout()));
|
||||
shutdownTimer->start(60000);
|
||||
}
|
||||
shutdownStateMutex.unlock();
|
||||
shutdownTimeout();
|
||||
}
|
||||
|
||||
|
|
@ -702,6 +717,7 @@ void Servatrice::incRxBytes(quint64 num)
|
|||
|
||||
void Servatrice::shutdownTimeout()
|
||||
{
|
||||
QMutexLocker locker(&shutdownStateMutex);
|
||||
// Show every time counter cut in half & every minute for last 5 minutes
|
||||
if (shutdownMinutes <= 5 || shutdownMinutes == nextShutdownMessageMinutes) {
|
||||
if (shutdownMinutes == nextShutdownMessageMinutes) {
|
||||
|
|
|
|||
|
|
@ -158,6 +158,7 @@ private:
|
|||
Servatrice_IslServer *islServer;
|
||||
mutable QMutex loginMessageMutex;
|
||||
QString loginMessage;
|
||||
mutable QMutex shutdownStateMutex;
|
||||
QString dbPrefix;
|
||||
QMap<QString, bool> serverRequiredFeatureList;
|
||||
QString officialWarnings;
|
||||
|
|
@ -216,6 +217,7 @@ public:
|
|||
QMutexLocker locker(&loginMessageMutex);
|
||||
return loginMessage;
|
||||
}
|
||||
SessionEvent *getLoginSessionEvent() const override;
|
||||
QString getRequiredFeatures() const override;
|
||||
QString getAuthenticationMethodString() const;
|
||||
QString getDBTypeString() const;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue