diff options
author | Morten Sorvig <msorvig@trolltech.com> | 2009-08-20 19:00:13 +0200 |
---|---|---|
committer | Morten Sorvig <msorvig@trolltech.com> | 2009-08-20 19:00:13 +0200 |
commit | 541b7c36250aa0338665a83fab6abf3bd30e36b2 (patch) | |
tree | b13eecaed1a558a3e92e2a8e71ffa0b163419f03 /src/webclientserver.cpp | |
parent | 957e3cc7e3722bd93f78976c68eba0e5a0535f61 (diff) |
Add an active session limit
Diffstat (limited to 'src/webclientserver.cpp')
-rw-r--r-- | src/webclientserver.cpp | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/src/webclientserver.cpp b/src/webclientserver.cpp index f690cf5..3e0f7eb 100644 --- a/src/webclientserver.cpp +++ b/src/webclientserver.cpp @@ -187,6 +187,8 @@ Server::Server(quint16 port) bytesRead = 0; serverStart = QDateTime::currentDateTime(); totalSessions = 0; + + activeSessionLimitHtml = "<html><body>Active session limit exceeded.</body></html>"; } Server::~Server() @@ -264,6 +266,13 @@ void Server::dataOnSocket() // ### accept unknown sessions for now, TODO do authentication here. DEBUG << "new session for" << sessionId; + if (totalSessions >= activeSessionLimit) { + dynamicBytesWritten += activeSessionLimitHtml.size(); + socket->write(activeSessionLimitHtml); + socket->disconnectFromHost(); + return; + } + ++totalSessions; sessionId = nextCookieId; nextCookieId = qrand(); // ### |