X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/980332313bffde590173f76fd006837e0c8f3bed..2741145e6eb219cb0ccb75e729b86f8fc2b499bb:/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 9ed7ffcf..dbb2993a 100644 --- a/projects/stargazer/plugins/authorization/ao/ao.h +++ b/projects/stargazer/plugins/authorization/ao/ao.h @@ -18,117 +18,114 @@ * Author : Boris Mikhailenko */ -/* - $Revision: 1.21 $ - $Date: 2010/09/10 06:38:26 $ - $Author: faust $ -*/ - -#ifndef AO_H -#define AO_H - -#include - -#include -#include +#pragma once #include "stg/auth.h" +#include "stg/module_settings.h" #include "stg/store.h" #include "stg/notifer.h" #include "stg/user_ips.h" #include "stg/user.h" #include "stg/logger.h" -extern "C" PLUGIN * GetPlugin(); +#include +#include +#include + +#include + +namespace STG +{ +struct Users; +} class AUTH_AO; -class USERS; -//----------------------------------------------------------------------------- + +using UserPtr = STG::User*; +using ConstUserPtr = const STG::User*; + template -class CHG_BEFORE_NOTIFIER : public PROPERTY_NOTIFIER_BASE { +class CHG_BEFORE_NOTIFIER : public STG::PropertyNotifierBase { public: - CHG_BEFORE_NOTIFIER(AUTH_AO & a, USER_PTR u) - : PROPERTY_NOTIFIER_BASE(), user(u), auth(a) {} + CHG_BEFORE_NOTIFIER(AUTH_AO & a, UserPtr u) + : user(u), auth(a) {} CHG_BEFORE_NOTIFIER(const CHG_BEFORE_NOTIFIER & rvalue) - : PROPERTY_NOTIFIER_BASE(), - user(rvalue.user), auth(rvalue.auth) {} + : user(rvalue.user), auth(rvalue.auth) {} void Notify(const T & oldValue, const T & newValue); - USER_PTR GetUser() const { return user; } + UserPtr GetUser() const { return user; } private: CHG_BEFORE_NOTIFIER & operator=(const CHG_BEFORE_NOTIFIER & rvalue); - USER_PTR user; + UserPtr user; const AUTH_AO & auth; }; //----------------------------------------------------------------------------- template -class CHG_AFTER_NOTIFIER : public PROPERTY_NOTIFIER_BASE { +class CHG_AFTER_NOTIFIER : public STG::PropertyNotifierBase { public: - CHG_AFTER_NOTIFIER(AUTH_AO & a, USER_PTR u) - : PROPERTY_NOTIFIER_BASE(), user(u), auth(a) {} + CHG_AFTER_NOTIFIER(AUTH_AO & a, UserPtr u) + : user(u), auth(a) {} CHG_AFTER_NOTIFIER(const CHG_AFTER_NOTIFIER & rvalue) - : PROPERTY_NOTIFIER_BASE(), - user(rvalue.user), auth(rvalue.auth) {} + : user(rvalue.user), auth(rvalue.auth) {} void Notify(const T & oldValue, const T & newValue); - USER_PTR GetUser() const { return user; } + UserPtr GetUser() const { return user; } private: CHG_AFTER_NOTIFIER & operator=(const CHG_AFTER_NOTIFIER & rvalue); - USER_PTR user; + UserPtr user; const AUTH_AO & auth; }; //----------------------------------------------------------------------------- -class AUTH_AO : public AUTH { +class AUTH_AO : public STG::Auth { public: AUTH_AO(); - virtual ~AUTH_AO(){} - void SetUsers(USERS * u) { users = u; } + void SetUsers(STG::Users * u) override { users = u; } - int Start(); - int Stop(); - int Reload(const MODULE_SETTINGS & /*ms*/) { return 0; } - bool IsRunning() { return isRunning; } - void SetSettings(const MODULE_SETTINGS &) {} - int ParseSettings() { return 0; } - const std::string & GetStrError() const { return errorStr; } - std::string GetVersion() const; - uint16_t GetStartPosition() const { return 30; } - uint16_t GetStopPosition() const { return 30; } + int Start() override; + int Stop() override; + int Reload(const STG::ModuleSettings & /*ms*/) override { return 0; } + bool IsRunning() override { return isRunning; } + void SetSettings(const STG::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; } - void AddUser(USER_PTR u); - void DelUser(USER_PTR u); - - int SendMessage(const STG_MSG & msg, uint32_t ip) const; + int SendMessage(const STG::Message & msg, uint32_t ip) const override; private: AUTH_AO(const AUTH_AO & rvalue); AUTH_AO & operator=(const AUTH_AO & rvalue); + void AddUser(UserPtr u); + void DelUser(UserPtr u); + void GetUsers(); - void SetUserNotifiers(USER_PTR u); - void UnSetUserNotifiers(USER_PTR u); - void UpdateUserAuthorization(CONST_USER_PTR u) const; + void SetUserNotifiers(UserPtr u); + void UnSetUserNotifiers(UserPtr u); + void UpdateUserAuthorization(ConstUserPtr u) const; mutable std::string errorStr; - USERS * users; - std::list usersList; + STG::Users * users; + std::vector userList; bool isRunning; - MODULE_SETTINGS settings; + STG::ModuleSettings settings; std::list > BeforeChgAONotifierList; std::list > AfterChgAONotifierList; - std::list > BeforeChgIPNotifierList; - std::list > AfterChgIPNotifierList; + std::list > BeforeChgIPNotifierList; + std::list > AfterChgIPNotifierList; - class ADD_USER_NONIFIER: public NOTIFIER_BASE { + class ADD_USER_NONIFIER: public STG::NotifierBase { public: - ADD_USER_NONIFIER(AUTH_AO & a) : auth(a) {} + explicit ADD_USER_NONIFIER(AUTH_AO & a) : auth(a) {} virtual ~ADD_USER_NONIFIER() {} - void Notify(const USER_PTR & user) { auth.AddUser(user); } + void Notify(const UserPtr & user) { auth.AddUser(user); } private: ADD_USER_NONIFIER(const ADD_USER_NONIFIER & rvalue); @@ -137,11 +134,11 @@ private: AUTH_AO & auth; } onAddUserNotifier; - class DEL_USER_NONIFIER: public NOTIFIER_BASE { + class DEL_USER_NONIFIER: public STG::NotifierBase { public: - DEL_USER_NONIFIER(AUTH_AO & a) : auth(a) {} + explicit DEL_USER_NONIFIER(AUTH_AO & a) : auth(a) {} virtual ~DEL_USER_NONIFIER() {} - void Notify(const USER_PTR & user) { auth.DelUser(user); } + void Notify(const UserPtr & user) { auth.DelUser(user); } private: DEL_USER_NONIFIER(const DEL_USER_NONIFIER & rvalue); @@ -149,14 +146,12 @@ private: AUTH_AO & auth; } onDelUserNotifier; - PLUGIN_LOGGER logger; + + STG::PluginLogger logger; friend class CHG_BEFORE_NOTIFIER; friend class CHG_AFTER_NOTIFIER; - friend class CHG_BEFORE_NOTIFIER; - friend class CHG_AFTER_NOTIFIER; + friend class CHG_BEFORE_NOTIFIER; + friend class CHG_AFTER_NOTIFIER; }; -//----------------------------------------------------------------------------- - -#endif