X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/ede91934442fd804d7b818971a44e3ad795cb01f..ebd170a764ab9660adee464588cda1801c7986b4:/projects/stargazer/plugins/authorization/ao/ao.h diff --git a/projects/stargazer/plugins/authorization/ao/ao.h b/projects/stargazer/plugins/authorization/ao/ao.h index 4c0c344a..319aeab1 100644 --- a/projects/stargazer/plugins/authorization/ao/ao.h +++ b/projects/stargazer/plugins/authorization/ao/ao.h @@ -18,146 +18,75 @@ * Author : Boris Mikhailenko */ -/* - $Revision: 1.21 $ - $Date: 2010/09/10 06:38:26 $ - $Author: faust $ -*/ - -#ifndef AO_H -#define AO_H +#pragma once -#include +#include "stg/auth.h" +#include "stg/module_settings.h" +#include "stg/store.h" +#include "stg/subscriptions.h" +#include "stg/user_ips.h" +#include "stg/user.h" +#include "stg/logger.h" #include +#include #include -#include "auth.h" -#include "store.h" -#include "notifer.h" -#include "user_ips.h" -#include "user.h" +#include -extern "C" PLUGIN * GetPlugin(); +namespace STG +{ +class Users; -class AUTH_AO; -class USERS; +using UserPtr = User*; +using ConstUserPtr = const User*; //----------------------------------------------------------------------------- -template -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; } - -private: - USER_PTR user; - const AUTH_AO & auth; -}; -//----------------------------------------------------------------------------- -template -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; } - -private: - 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 { -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 *) {} - - int Start(); - int Stop(); - int Reload() { return 0; } - bool IsRunning(); - void SetSettings(const MODULE_SETTINGS & s); - int ParseSettings(); - const std::string & GetStrError() const; - const std::string GetVersion() const; - uint16_t GetStartPosition() const; - uint16_t GetStopPosition() const; - - 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); - - 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 > BeforeChgIPNotifierList; - list > AfterChgIPNotifierList; - - class ADD_USER_NONIFIER: public NOTIFIER_BASE { +class AUTH_AO : public Auth +{ public: - ADD_USER_NONIFIER(AUTH_AO & a) : auth(a) {} - virtual ~ADD_USER_NONIFIER() {} + AUTH_AO(); + + void SetUsers(Users * u) override { users = u; } - void Notify(const USER_PTR & user) - { - auth.AddUser(user); - } + int Start() override; + int Stop() override; + int Reload(const ModuleSettings & /*ms*/) override { return 0; } + bool IsRunning() override { return isRunning; } + void SetSettings(const ModuleSettings &) override {} + int ParseSettings() override { return 0; } + const std::string & GetStrError() const override { return errorStr; } + std::string GetVersion() const override; + uint16_t GetStartPosition() const override { return 30; } + uint16_t GetStopPosition() const override { return 30; } + + int SendMessage(const Message & msg, uint32_t ip) const override; private: - AUTH_AO & auth; - } onAddUserNotifier; + AUTH_AO(const AUTH_AO & rvalue); + AUTH_AO & operator=(const AUTH_AO & rvalue); - class DEL_USER_NONIFIER: public NOTIFIER_BASE { - public: - DEL_USER_NONIFIER(AUTH_AO & a) : auth(a) {} - virtual ~DEL_USER_NONIFIER() {} + void AddUser(UserPtr u); + void DelUser(UserPtr u); - void Notify(const USER_PTR & user) - { - auth.DelUser(user); - } + void GetUsers(); + void SetUserNotifiers(UserPtr u); + void UnSetUserNotifiers(UserPtr u); + void UpdateUserAuthorization(ConstUserPtr u) const; + void Unauthorize(UserPtr u); - private: - AUTH_AO & auth; - } onDelUserNotifier; + mutable std::string errorStr; + Users * users; + std::vector userList; + bool isRunning; + ModuleSettings settings; + + using ConnHolder = std::tuple; + std::vector m_conns; + ScopedConnection m_onAddUserConn; + ScopedConnection m_onDelUserConn; + + PluginLogger logger; }; -//----------------------------------------------------------------------------- -#endif +}