mirror of
https://github.com/znc/znc.git
synced 2026-03-28 17:42:41 +01:00
Generate session IDs more securely
We now use a lot more data for generating the session id which is fed to a hash to make it impossible to attack specific parts of the input. Also we now retry generating a new session id in the (improbable) case of collision with an existing session id. Thanks a lot to cnu for pointing out the weakness in the old code by stealing my session cookie, you evil hacker! git-svn-id: https://znc.svn.sourceforge.net/svnroot/znc/trunk@1819 726aef4b-f618-498e-8847-2d620e286838
This commit is contained in:
@@ -27,11 +27,6 @@ bool CZNCTagHandler::HandleTag(CTemplate& Tmpl, const CString& sName, const CStr
|
||||
}
|
||||
|
||||
CWebSession::CWebSession(const CString& sId) : m_sId(sId) {
|
||||
if (m_sId.empty()) {
|
||||
m_sId = CString::RandomString(32);
|
||||
DEBUG("Auto generated session: [" + m_sId + "]");
|
||||
}
|
||||
|
||||
m_bLoggedIn = false;
|
||||
m_pUser = NULL;
|
||||
}
|
||||
@@ -601,7 +596,7 @@ void CWebSock::PrintErrorPage(const CString& sMessage) {
|
||||
m_Template["Error"] = sMessage;
|
||||
}
|
||||
|
||||
CSmartPtr<CWebSession> CWebSock::GetSession() const {
|
||||
CSmartPtr<CWebSession> CWebSock::GetSession() {
|
||||
if (!m_spSession.IsNull()) {
|
||||
return m_spSession;
|
||||
}
|
||||
@@ -613,7 +608,18 @@ CSmartPtr<CWebSession> CWebSock::GetSession() const {
|
||||
return it->second;
|
||||
}
|
||||
|
||||
CSmartPtr<CWebSession> spSession(new CWebSession());
|
||||
CString sSessionID;
|
||||
do {
|
||||
sSessionID = CString::RandomString(32);
|
||||
sSessionID += ":" + GetRemoteIP() + ":" + CString(GetRemotePort());
|
||||
sSessionID += ":" + GetLocalIP() + ":" + CString(GetLocalPort());
|
||||
sSessionID += ":" + CString(time(NULL));
|
||||
sSessionID = sSessionID.SHA256();
|
||||
|
||||
DEBUG("Auto generated session: [" + sSessionID + "]");
|
||||
} while (m_mspSessions.find(sSessionID) != m_mspSessions.end());
|
||||
|
||||
CSmartPtr<CWebSession> spSession(new CWebSession(sSessionID));
|
||||
m_mspSessions.insert(make_pair(spSession->GetId(), spSession));
|
||||
|
||||
return spSession;
|
||||
@@ -640,7 +646,7 @@ Csock* CWebSock::GetSockObj(const CString& sHost, unsigned short uPort) {
|
||||
return pSock;
|
||||
}
|
||||
|
||||
CString CWebSock::GetSkinName() const {
|
||||
CString CWebSock::GetSkinName() {
|
||||
CSmartPtr<CWebSession> spSession = GetSession();
|
||||
|
||||
if (spSession->IsLoggedIn() && !spSession->GetUser()->GetSkinName().empty()) {
|
||||
|
||||
Reference in New Issue
Block a user