ECSessionGroupManager.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. /*
  2. * Copyright 2005 - 2016 Zarafa and its licensors
  3. *
  4. * This program is free software: you can redistribute it and/or modify
  5. * it under the terms of the GNU Affero General Public License, version 3,
  6. * as published by the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU Affero General Public License for more details.
  12. *
  13. * You should have received a copy of the GNU Affero General Public License
  14. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. *
  16. */
  17. #ifndef ECSESSIONGROUPMANAGER_H
  18. #define ECSESSIONGROUPMANAGER_H
  19. #include <kopano/zcdefs.h>
  20. #include <algorithm>
  21. #include <list>
  22. #include <map>
  23. #include <mutex>
  24. #include <string>
  25. #include "SessionGroupData.h"
  26. #include "ClientUtil.h"
  27. typedef std::map<ECSessionGroupInfo, ECSESSIONGROUPID> SESSIONGROUPIDMAP;
  28. typedef std::map<ECSessionGroupInfo, SessionGroupData*> SESSIONGROUPMAP;
  29. class ECSessionGroupManager _kc_final {
  30. private:
  31. /*
  32. * Both maps must be protected under the same mutx: m_hMutex
  33. */
  34. SESSIONGROUPIDMAP m_mapSessionGroupIds;
  35. SESSIONGROUPMAP m_mapSessionGroups;
  36. std::recursive_mutex m_hMutex;
  37. public:
  38. /* Gets the session id by connect parameters */
  39. ECSESSIONGROUPID GetSessionGroupId(const sGlobalProfileProps &sProfileProps);
  40. /* Gets or creates a session group with the specified ID and connect parameters */
  41. HRESULT GetSessionGroupData(ECSESSIONGROUPID ecSessionGroupId, const sGlobalProfileProps &sProfileProps, SessionGroupData **lppData);
  42. /* Cleanup callback when SessionGroupData object is deleted (should only be called from SessionGroupData::~SessionGroupData() */
  43. HRESULT DeleteSessionGroupDataIfOrphan(ECSESSIONGROUPID ecSessionGroupId);
  44. };
  45. /* Global SessionManager for entire client */
  46. extern ECSessionGroupManager g_ecSessionManager;
  47. #endif /* ECSESSIONGROUPMANAGER_H */