X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/e9ae1f101b5418c0ba2e6c9d86b23c12f0140982..b2b89723a2427bba8290bd6967a1ab39cbb630be:/include/stg/users.h?ds=sidebyside diff --git a/include/stg/users.h b/include/stg/users.h index 04b15605..a0be8493 100644 --- a/include/stg/users.h +++ b/include/stg/users.h @@ -20,57 +20,64 @@ #pragma once -#include "notifer.h" +#include "subscriptions.h" #include +#include + namespace STG { -struct Admin; -struct User; +class Admin; +class User; struct Auth; -struct Users { - virtual ~Users() = default; +class Users +{ + public: + virtual ~Users() = default; - using UserPtr = User*; - using ConstUserPtr = const User*; + using UserPtr = User*; + using ConstUserPtr = const User*; - virtual int FindByName(const std::string& login, UserPtr* user) = 0; - virtual int FindByName(const std::string& login, ConstUserPtr* user) const = 0; - virtual bool Exists(const std::string& login) const = 0; + virtual int FindByName(const std::string& login, UserPtr* user) = 0; + virtual int FindByName(const std::string& login, ConstUserPtr* user) const = 0; + virtual bool Exists(const std::string& login) const = 0; - virtual bool TariffInUse(const std::string& tariffName) const = 0; + virtual bool TariffInUse(const std::string& tariffName) const = 0; - virtual void AddNotifierUserAdd(NotifierBase* notifier) = 0; - virtual void DelNotifierUserAdd(NotifierBase* notifier) = 0; + template + auto onAdd(F&& f) { return m_onAddCallbacks.add(std::forward(f)); } + template + auto onDel(F&& f) { return m_onDelCallbacks.add(std::forward(f)); } - virtual void AddNotifierUserDel(NotifierBase* notifier) = 0; - virtual void DelNotifierUserDel(NotifierBase* notifier) = 0; + virtual int Add(const std::string& login, const Admin* admin) = 0; + virtual void Del(const std::string& login, const Admin* admin) = 0; - virtual int Add(const std::string& login, const Admin* admin) = 0; - virtual void Del(const std::string& login, const Admin* admin) = 0; + virtual bool Authorize(const std::string& login, uint32_t ip, + uint32_t enabledDirs, const Auth* auth) = 0; + virtual bool Unauthorize(const std::string& login, + const Auth* auth, + const std::string& reason = {}) = 0; - virtual bool Authorize(const std::string& login, uint32_t ip, - uint32_t enabledDirs, const Auth* auth) = 0; - virtual bool Unauthorize(const std::string& login, - const Auth* auth, - const std::string& reason = {}) = 0; + virtual int ReadUsers() = 0; + virtual size_t Count() const = 0; - virtual int ReadUsers() = 0; - virtual size_t Count() const = 0; + virtual int FindByIPIdx(uint32_t ip, User** user) const = 0; + virtual bool IsIPInIndex(uint32_t ip) const = 0; + virtual bool IsIPInUse(uint32_t ip, const std::string & login, const User** user) const = 0; - virtual int FindByIPIdx(uint32_t ip, User** user) const = 0; - virtual bool IsIPInIndex(uint32_t ip) const = 0; - virtual bool IsIPInUse(uint32_t ip, const std::string & login, const User** user) const = 0; + virtual unsigned int OpenSearch() = 0; + virtual int SearchNext(int handle, User** u) = 0; + virtual int CloseSearch(int handle) = 0; - virtual int OpenSearch() = 0; - virtual int SearchNext(int handle, User** u) = 0; - virtual int CloseSearch(int handle) = 0; + virtual int Start() = 0; + virtual int Stop() = 0; - virtual int Start() = 0; - virtual int Stop() = 0; + protected: + Subscriptions m_onAddCallbacks; + Subscriptions m_onDelCallbacks; }; }