]> git.stg.codes - stg.git/blobdiff - projects/stargazer/plugins/configuration/sgconfig/parser_user_info.h
Merge remote-tracking branch 'origin/ticket'
[stg.git] / projects / stargazer / plugins / configuration / sgconfig / parser_user_info.h
index 91b022f1104840341490c3b9ed0f030be0759ba8..76153f573e512acade527ff4003c6417cf74144e 100644 (file)
 #ifndef __STG_PARSER_USER_INFO_H__
 #define __STG_PARSER_USER_INFO_H__
 
+#include "parser.h"
+
+#include "stg/common.h"
+
 #include <string>
 
-#include "parser.h"
+class USERS;
 
-class PARSER_USER_INFO : public BASE_PARSER {
-public:
-    int ParseStart(void *data, const char *el, const char **attr);
-    int ParseEnd(void *data, const char *el);
+namespace STG
+{
+namespace PARSER
+{
 
-private:
-    std::string login;
+class USER_INFO : 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 USER_INFO(admin, m_users); }
+                static void Register(REGISTRY & registry, const USERS & users)
+                { registry[ToLower(tag)] = new FACTORY(users); }
+            private:
+                const USERS & m_users;
+        };
 
-    void CreateAnswer();
+        static const char * tag;
+
+        USER_INFO(const ADMIN & admin, const USERS & users)
+            : BASE_PARSER(admin, tag), m_users(users) {}
+        int Start(void * data, const char * el, const char ** attr);
+
+    private:
+        const USERS & m_users;
+        std::string m_login;
+
+        void CreateAnswer();
 };
 
+} // namespace PARSER
+} // namespace STG
+
 #endif