X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/3df642f3d2537dc5531a8d91c6d85927b34b46c7..4243cf76394d6e657a1a8b67645d3d655efd1b07:/projects/stargazer/plugins/configuration/sgconfig/parser.h?ds=sidebyside diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser.h b/projects/stargazer/plugins/configuration/sgconfig/parser.h index df3d7155..81bd454b 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/parser.h +++ b/projects/stargazer/plugins/configuration/sgconfig/parser.h @@ -1,26 +1,43 @@ - /* - $Revision: 1.20 $ - $Date: 2010/10/04 20:26:10 $ - $Author: faust $ +/* + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + */ + +/* + * Author : Boris Mikhailenko */ #ifndef PARSER_H #define PARSER_H -#include -#include -#include - +#include "stg/message.h" +#include "stg/tariff_conf.h" #include "stg/resetable.h" #include "stg/const.h" -#include "stg/store.h" -#include "stg/admins.h" -#include "stg/admin.h" -#include "stg/users.h" -#include "stg/message.h" + +#include +#include class TARIFFS; class SETTINGS; +class STORE; +class ADMINS; +class ADMIN; +class USERS; +class USER; +class USER_STAT_RES; +class USER_CONF_RES; //----------------------------------------------------------------------------- class BASE_PARSER { @@ -33,24 +50,22 @@ public: store(NULL), settings(NULL), currAdmin(NULL), - depth(0), - answerList(NULL) + depth(0) {} virtual ~BASE_PARSER() {} virtual int ParseStart(void *data, const char *el, const char **attr) = 0; virtual int ParseEnd(void *data, const char *el) = 0; - virtual void CreateAnswer() = 0; - virtual void SetAnswerList(std::list * ansList) { answerList = ansList; } + virtual void Reset() { answer.clear(); depth = 0; } - virtual void SetUsers(USERS * u) { users = u; } - virtual void SetAdmins(ADMINS * a) { admins = a; } - virtual void SetTariffs(TARIFFS * t) { tariffs = t; } - virtual void SetStore(STORE * s) { store = s; } - virtual void SetStgSettings(const SETTINGS * s) { settings = s; } + void SetUsers(USERS * u) { users = u; } + void SetAdmins(ADMINS * a) { admins = a; } + void SetTariffs(TARIFFS * t) { tariffs = t; } + void SetStore(STORE * s) { store = s; } + void SetStgSettings(const SETTINGS * s) { settings = s; } - virtual void SetCurrAdmin(ADMIN & cua) { currAdmin = &cua; } - virtual std::string & GetStrError() { return strError; } - virtual void Reset() { answerList->clear(); depth = 0; } + void SetCurrAdmin(ADMIN & cua) { currAdmin = &cua; } + const std::string & GetStrError() const { return strError; } + const std::string & GetAnswer() const { return answer; } protected: BASE_PARSER(const BASE_PARSER & rvalue); @@ -64,13 +79,15 @@ protected: const SETTINGS * settings; ADMIN * currAdmin; int depth; - std::list * answerList; + std::string answer; }; //----------------------------------------------------------------------------- class PARSER_GET_ADMINS: public BASE_PARSER { public: int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); + +private: void CreateAnswer(); }; //----------------------------------------------------------------------------- @@ -79,9 +96,11 @@ public: PARSER_ADD_ADMIN() : BASE_PARSER(), adminToAdd() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: std::string adminToAdd; + + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_DEL_ADMIN: public BASE_PARSER { @@ -89,10 +108,11 @@ public: PARSER_DEL_ADMIN() : BASE_PARSER(), adminToDel() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: - int CheckAttr(const char **attr); std::string adminToDel; + + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_CHG_ADMIN: public BASE_PARSER { @@ -100,17 +120,21 @@ public: PARSER_CHG_ADMIN() : BASE_PARSER(), login(), password(), privAsString() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: RESETABLE login; RESETABLE password; RESETABLE privAsString; + + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_GET_SERVER_INFO: public BASE_PARSER { public: int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); + +private: void CreateAnswer(); }; //----------------------------------------------------------------------------- @@ -120,9 +144,11 @@ public: ~PARSER_GET_USER() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: std::string login; + + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_GET_USERS: public BASE_PARSER { @@ -130,16 +156,20 @@ public: PARSER_GET_USERS() : BASE_PARSER(), lastUserUpdateTime(0), lastUpdateFound(false) {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: time_t lastUserUpdateTime; bool lastUpdateFound; + + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_GET_TARIFFS: public BASE_PARSER { public: int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); + +private: void CreateAnswer(); }; //----------------------------------------------------------------------------- @@ -148,9 +178,11 @@ public: PARSER_ADD_TARIFF() : BASE_PARSER(), tariffToAdd() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: std::string tariffToAdd; + + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_DEL_TARIFF: public BASE_PARSER { @@ -158,9 +190,11 @@ public: PARSER_DEL_TARIFF() : BASE_PARSER(), tariffToDel() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: std::string tariffToDel; + + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_CHG_TARIFF: public BASE_PARSER { @@ -168,14 +202,15 @@ public: PARSER_CHG_TARIFF() : BASE_PARSER(), td() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: + TARIFF_DATA_RES td; + int ParseSlashedIntParams(int paramsNum, const std::string & s, int * params); int ParseSlashedDoubleParams(int paramsNum, const std::string & s, double * params); int CheckTariffData(); int AplayChanges(); - - TARIFF_DATA_RES td; + void CreateAnswer(); }; //-----------------------------------------------------------------------------/ class PARSER_ADD_USER: public BASE_PARSER { @@ -184,11 +219,13 @@ public: ~PARSER_ADD_USER() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); - void Reset(); + private: - int CheckUserData(); std::string login; + + int CheckUserData(); + void CreateAnswer(); + void Reset(); }; //----------------------------------------------------------------------------- class PARSER_CHG_USER: public BASE_PARSER { @@ -197,15 +234,8 @@ public: ~PARSER_CHG_USER(); int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); - void Reset(); -private: - PARSER_CHG_USER(const PARSER_CHG_USER & rvalue); - PARSER_CHG_USER & operator=(const PARSER_CHG_USER & rvalue); - - std::string EncChar2String(const char *); - int AplayChanges(); +private: USER_STAT_RES * usr; USER_CONF_RES * ucr; RESETABLE * upr; @@ -214,6 +244,14 @@ private: std::string login; bool cashMustBeAdded; int res; + + PARSER_CHG_USER(const PARSER_CHG_USER & rvalue); + PARSER_CHG_USER & operator=(const PARSER_CHG_USER & rvalue); + + std::string EncChar2String(const char *); + int AplayChanges(); + void CreateAnswer(); + void Reset(); }; //----------------------------------------------------------------------------- class PARSER_DEL_USER: public BASE_PARSER { @@ -221,24 +259,25 @@ public: PARSER_DEL_USER() : BASE_PARSER(), res(0), u(NULL) {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); private: + int res; + USER * u; + PARSER_DEL_USER(const PARSER_DEL_USER & rvalue); PARSER_DEL_USER & operator=(const PARSER_DEL_USER & rvalue); - int res; - USER * u; + void CreateAnswer(); }; //----------------------------------------------------------------------------- class PARSER_CHECK_USER: public BASE_PARSER { public: - PARSER_CHECK_USER() : BASE_PARSER(), result(false) {} + PARSER_CHECK_USER() : BASE_PARSER() {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); + private: - bool result; + void CreateAnswer(const char * error); }; //----------------------------------------------------------------------------- class PARSER_SEND_MESSAGE: public BASE_PARSER { @@ -246,18 +285,19 @@ public: PARSER_SEND_MESSAGE() : BASE_PARSER(), logins(), result(0), msg(), u(NULL) {} int ParseStart(void *data, const char *el, const char **attr); int ParseEnd(void *data, const char *el); - void CreateAnswer(); -private: - PARSER_SEND_MESSAGE(const PARSER_SEND_MESSAGE & rvalue); - PARSER_SEND_MESSAGE & operator=(const PARSER_SEND_MESSAGE & rvalue); - - int ParseLogins(const char * logins); +private: enum {res_ok, res_params_error, res_unknown}; std::vector logins; int result; STG_MSG msg; USER * u; + + PARSER_SEND_MESSAGE(const PARSER_SEND_MESSAGE & rvalue); + PARSER_SEND_MESSAGE & operator=(const PARSER_SEND_MESSAGE & rvalue); + + int ParseLogins(const char * logins); + void CreateAnswer(); }; //----------------------------------------------------------------------------- #endif //PARSER_H