123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122 |
- #include <kopano/platform.h>
- #include <kopano/lockhelper.hpp>
- #include <mapicode.h>
- #include <mapix.h>
- #include "ECNotifyMaster.h"
- #include "ECSessionGroupManager.h"
- #include "SessionGroupData.h"
- #include "SSLUtil.h"
- struct findSessionGroupId {
- ECSESSIONGROUPID ecSessionGroupId;
- findSessionGroupId(ECSESSIONGROUPID ecSessionGroupId) : ecSessionGroupId(ecSessionGroupId)
- {
- }
- bool operator()(const SESSIONGROUPMAP::value_type &entry) const
- {
- return entry.second->GetSessionGroupId() == ecSessionGroupId;
- }
- };
- ECSessionGroupManager g_ecSessionManager;
- ECSESSIONGROUPID ECSessionGroupManager::GetSessionGroupId(const sGlobalProfileProps &sProfileProps)
- {
- ECSESSIONGROUPID ecSessionGroupId;
- scoped_rlock lock(m_hMutex);
- ECSessionGroupInfo ecSessionGroup = ECSessionGroupInfo(sProfileProps.strServerPath, sProfileProps.strProfileName);
- auto result = m_mapSessionGroupIds.insert(SESSIONGROUPIDMAP::value_type(ecSessionGroup, 0));
- if (result.second == true) {
-
- ssl_random((sizeof(ecSessionGroupId) == 8), &ecSessionGroupId);
-
-
-
-
- result.first->second = ecSessionGroupId;
- }
- else {
- ecSessionGroupId = result.first->second;
- }
- return ecSessionGroupId;
- }
- HRESULT ECSessionGroupManager::GetSessionGroupData(ECSESSIONGROUPID ecSessionGroupId, const sGlobalProfileProps &sProfileProps, SessionGroupData **lppData)
- {
- HRESULT hr = hrSuccess;
- ECSessionGroupInfo ecSessionGroup = ECSessionGroupInfo(sProfileProps.strServerPath, sProfileProps.strProfileName);
- SessionGroupData *lpData = NULL;
- scoped_rlock lock(m_hMutex);
- auto result = m_mapSessionGroups.insert(SESSIONGROUPMAP::value_type(ecSessionGroup, NULL));
- if (result.second == true) {
- hr = SessionGroupData::Create(ecSessionGroupId, &ecSessionGroup, sProfileProps, &lpData);
- if (hr == hrSuccess)
- result.first->second = lpData;
- else
- m_mapSessionGroups.erase(result.first);
- } else {
- lpData = result.first->second;
- lpData->AddRef();
- }
- *lppData = lpData;
- return hr;
- }
- HRESULT ECSessionGroupManager::DeleteSessionGroupDataIfOrphan(ECSESSIONGROUPID ecSessionGroupId)
- {
- HRESULT hr = hrSuccess;
- SessionGroupData *lpSessionGroupData = NULL;
- ulock_rec biglock(m_hMutex);
- auto iter = find_if(m_mapSessionGroups.cbegin(), m_mapSessionGroups.cend(), findSessionGroupId(ecSessionGroupId));
- if (iter != m_mapSessionGroups.cend()) {
- if(iter->second->IsOrphan()) {
-
-
-
- lpSessionGroupData = iter->second;
- m_mapSessionGroups.erase(iter);
- }
- }
- biglock.unlock();
-
-
-
- delete lpSessionGroupData;
- return hr;
- }
|