X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/ede91934442fd804d7b818971a44e3ad795cb01f..bd81e49c054c7a196c01e901a5e41f6896bad4d8:/projects/stargazer/plugins/authorization/ao/ao.h?ds=sidebyside diff --git a/projects/stargazer/plugins/authorization/ao/ao.h b/projects/stargazer/plugins/authorization/ao/ao.h index 4c0c344a..df21803b 100644 --- a/projects/stargazer/plugins/authorization/ao/ao.h +++ b/projects/stargazer/plugins/authorization/ao/ao.h @@ -32,11 +32,11 @@ #include #include -#include "auth.h" -#include "store.h" -#include "notifer.h" -#include "user_ips.h" -#include "user.h" +#include "stg/auth.h" +#include "stg/store.h" +#include "stg/notifer.h" +#include "stg/user_ips.h" +#include "stg/user.h" extern "C" PLUGIN * GetPlugin(); @@ -44,90 +44,69 @@ class AUTH_AO; class USERS; //----------------------------------------------------------------------------- template -class CHG_BEFORE_NOTIFIER: public PROPERTY_NOTIFIER_BASE { +class CHG_BEFORE_NOTIFIER : public PROPERTY_NOTIFIER_BASE { public: CHG_BEFORE_NOTIFIER(AUTH_AO & a, USER_PTR u) : user(u), auth(a) {} void Notify(const varParamType & oldValue, const varParamType & newValue); - USER_PTR GetUser() const { return user; } + USER_PTR GetUser() const { return user; } private: - USER_PTR user; - const AUTH_AO & auth; + USER_PTR user; + const AUTH_AO & auth; }; //----------------------------------------------------------------------------- template -class CHG_AFTER_NOTIFIER: public PROPERTY_NOTIFIER_BASE { +class CHG_AFTER_NOTIFIER : public PROPERTY_NOTIFIER_BASE { public: CHG_AFTER_NOTIFIER(AUTH_AO & a, USER_PTR u) : user(u), auth(a) {} void Notify(const varParamType & oldValue, const varParamType & newValue); - USER_PTR GetUser() const { return user; } + USER_PTR GetUser() const { return user; } private: - USER_PTR user; + USER_PTR user; const AUTH_AO & auth; }; //----------------------------------------------------------------------------- -class AUTH_AO_SETTINGS { -public: - const std::string & GetStrError() const { static std::string s; return s; } - int ParseSettings(const MODULE_SETTINGS &) { return 0; } -}; -//----------------------------------------------------------------------------- -class AUTH_AO :public AUTH { +class AUTH_AO : public AUTH { public: AUTH_AO(); virtual ~AUTH_AO(){}; - void SetUsers(USERS * u); - void SetTariffs(TARIFFS *) {} - void SetAdmins(ADMINS *) {} - void SetTraffcounter(TRAFFCOUNTER *) {} - void SetStore(STORE *) {} - void SetStgSettings(const SETTINGS *) {} + void SetUsers(USERS * u) { users = u; } int Start(); int Stop(); int Reload() { return 0; } - bool IsRunning(); - void SetSettings(const MODULE_SETTINGS & s); - int ParseSettings(); - const std::string & GetStrError() const; + bool IsRunning() { return isRunning; } + void SetSettings(const MODULE_SETTINGS &) {} + int ParseSettings() { return 0; } + const std::string & GetStrError() const { return errorStr; } const std::string GetVersion() const; - uint16_t GetStartPosition() const; - uint16_t GetStopPosition() const; + uint16_t GetStartPosition() const { return 70; } + uint16_t GetStopPosition() const { return 70; } void AddUser(USER_PTR u); void DelUser(USER_PTR u); - void UpdateUserAuthorization(USER_PTR u) const; - void Unauthorize(USER_PTR u) const; - int SendMessage(const STG_MSG & msg, uint32_t ip) const; private: void GetUsers(); void SetUserNotifiers(USER_PTR u); void UnSetUserNotifiers(USER_PTR u); + void UpdateUserAuthorization(CONST_USER_PTR u) const; mutable std::string errorStr; - AUTH_AO_SETTINGS aoSettings; USERS * users; std::list usersList; bool isRunning; MODULE_SETTINGS settings; - /* - ÍÙ ÄÏÌÖÎÙ ÐÅÒÅÐÒÏ×ÅÒÉÔØ ×ÏÚÍÏÖÎÏÓÔØ Á×ÔÏÒÉÚÁÃÉÉ ÀÚÅÒÁ ÐÒÉ ÉÚÍÅÎÅÎÉÉ - ÓÌÅÄÕÀÝÉÈ ÅÇÏ ÐÁÒÁÍÅÔÒÏ×: - - alwaysOnline - - ips - */ - - list > BeforeChgAONotifierList; - list > AfterChgAONotifierList; + list > BeforeChgAONotifierList; + list > AfterChgAONotifierList; - list > BeforeChgIPNotifierList; - list > AfterChgIPNotifierList; + list > BeforeChgIPNotifierList; + list > AfterChgIPNotifierList; class ADD_USER_NONIFIER: public NOTIFIER_BASE { public: @@ -157,6 +136,11 @@ private: AUTH_AO & auth; } onDelUserNotifier; + friend class CHG_BEFORE_NOTIFIER; + friend class CHG_AFTER_NOTIFIER; + friend class CHG_BEFORE_NOTIFIER; + friend class CHG_AFTER_NOTIFIER; + }; //-----------------------------------------------------------------------------