X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/250a7d6e7a4c8ffd644931b7b3964289a8f99151..47b9e5ee87451a8a701e40cc1c027118ff309d72:/projects/stargazer/plugins/configuration/sgconfig/parser_auth_by.h?ds=sidebyside diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser_auth_by.h b/projects/stargazer/plugins/configuration/sgconfig/parser_auth_by.h index c103147e..9a2e81a8 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/parser_auth_by.h +++ b/projects/stargazer/plugins/configuration/sgconfig/parser_auth_by.h @@ -23,6 +23,8 @@ #include "parser.h" +#include "stg/common.h" + #include class ADMIN; @@ -36,8 +38,21 @@ namespace PARSER class AUTH_BY : public BASE_PARSER { public: + class FACTORY : public BASE_PARSER::FACTORY + { + public: + FACTORY(const USERS & users) : m_users(users) {} + virtual BASE_PARSER * create(const ADMIN & admin) { return new AUTH_BY(admin, m_users); } + static void Register(REGISTRY & registry, const USERS & users) + { registry[ToLower(tag)] = new FACTORY(users); } + private: + const USERS & m_users; + }; + + static const char * tag; + AUTH_BY(const ADMIN & admin, const USERS & users) - : BASE_PARSER(admin, "GetUserAuthBy"), m_users(users) {} + : BASE_PARSER(admin, tag), m_users(users) {} int Start(void * data, const char * el, const char ** attr); private: @@ -47,7 +62,7 @@ class AUTH_BY : public BASE_PARSER void CreateAnswer(); }; -} -} +} // namespace PARSER +} // namespace STG #endif