X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/6d5f129aad1a6cbaf4d1441c68398e00fa949185..refs/heads/ticket:/stglibs/srvconf.lib/include/stg/servconf.h?ds=sidebyside diff --git a/stglibs/srvconf.lib/include/stg/servconf.h b/stglibs/srvconf.lib/include/stg/servconf.h index c62161be..cd37e49e 100644 --- a/stglibs/srvconf.lib/include/stg/servconf.h +++ b/stglibs/srvconf.lib/include/stg/servconf.h @@ -16,118 +16,96 @@ /* * Author : Boris Mikhailenko + * Author : Maxim Mamontov */ - /* - $Revision: 1.10 $ - $Date: 2009/03/17 09:52:35 $ - $Author: faust $ - */ - -#ifndef SERVCONF_H -#define SERVCONF_H - -#include "netunit.h" +#ifndef __STG_STGLIBS_SERVCONF_H__ +#define __STG_STGLIBS_SERVCONF_H__ -#include "stg/parser_auth_by.h" -#include "stg/parser_server_info.h" -#include "stg/parser_check_user.h" -#include "stg/parser_get_user.h" -#include "stg/parser_get_users.h" -#include "stg/parser_chg_user.h" +#include "stg/servconf_types.h" +#include "stg/admin_conf.h" #include "stg/os_int.h" -#include "stg/const.h" -#include -#include #include -#include +struct USER_CONF_RES; +struct USER_STAT_RES; +struct TARIFF_DATA_RES; +struct SERVICE_CONF_RES; +struct CORP_CONF_RES; -void Start(void * data, const char * el, const char ** attr); -void End(void * data, const char * el); - -#define MAX_ERR_STR_LEN (64) -#define IP_STRING_LEN (255) -//----------------------------------------------------------------------------- -typedef int (* RecvSendMessageCb_t)(const char * answer, void * data); -//----------------------------------------------------------------------------- -struct ADMINDATA +namespace STG { - char login[ADM_LOGIN_LEN]; -}; -//----------------------------------------------------------------------------- -class PARSER_SEND_MESSAGE: public PARSER -{ -public: - PARSER_SEND_MESSAGE(); - int ParseStart(const char * el, const char ** attr); - void ParseEnd(const char * el); - void ParseAnswer(const char * el, const char ** attr); - void SetSendMessageRecvCb(RecvSendMessageCb_t, void * data); -private: - RecvSendMessageCb_t RecvSendMessageCb; - void * sendMessageCbData; - int depth; -}; -//----------------------------------------------------------------------------- + class SERVCONF { public: - SERVCONF(); - void SetServer(const char * server); - void SetPort(uint16_t port); - - void SetAdmLogin(const char * login); - void SetAdmPassword(const char * password); - - void SetGetUsersCallback(PARSER_GET_USERS::CALLBACK f, void * data); - void SetAuthByCallback(PARSER_AUTH_BY::CALLBACK f, void * data); - void SetServerInfoCallback(PARSER_SERVER_INFO::CALLBACK f, void * data); - void SetChgUserCallback(PARSER_CHG_USER::CALLBACK f, void * data); - void SetCheckUserCallback(PARSER_CHECK_USER::CALLBACK f, void * data); - void SetGetUserCallback(PARSER_GET_USER::CALLBACK f, void * data); - void SetSendMessageCb(RecvSendMessageCb_t, void * data); - - int GetUsers(); - int GetUser(const char * login); - int ChgUser(const char * request); - int AuthBy(const char * login); - // TODO: Remove this shit! - int MsgUser(const char * request); - int SendMessage(const char * login, const char * message, int prio); - int ServerInfo(); - int CheckUser(const char * login, const char * password); + SERVCONF(const std::string & server, uint16_t port, + const std::string & login, const std::string & password); + SERVCONF(const std::string & server, uint16_t port, + const std::string & localAddress, uint16_t localPort, + const std::string & login, const std::string & password); + ~SERVCONF(); + + int ServerInfo(SERVER_INFO::CALLBACK f, void * data); + + int RawXML(const std::string & request, RAW_XML::CALLBACK f, void * data); + + int GetAdmins(GET_CONTAINER::CALLBACK::TYPE f, void * data); + int GetAdmin(const std::string & login, GET_ADMIN::CALLBACK f, void * data); + int ChgAdmin(const ADMIN_CONF_RES & conf, SIMPLE::CALLBACK f, void * data); + int AddAdmin(const std::string & login, + const ADMIN_CONF_RES & conf, + SIMPLE::CALLBACK f, void * data); + int DelAdmin(const std::string & login, SIMPLE::CALLBACK f, void * data); + + int GetTariffs(GET_CONTAINER::CALLBACK::TYPE f, void * data); + int GetTariff(const std::string & name, GET_TARIFF::CALLBACK f, void * data); + int ChgTariff(const TARIFF_DATA_RES & conf, SIMPLE::CALLBACK f, void * data); + int AddTariff(const std::string & name, + const TARIFF_DATA_RES & conf, + SIMPLE::CALLBACK f, void * data); + int DelTariff(const std::string & name, SIMPLE::CALLBACK f, void * data); + + int GetUsers(GET_CONTAINER::CALLBACK::TYPE f, void * data); + int GetUser(const std::string & login, GET_USER::CALLBACK f, void * data); + int ChgUser(const std::string & login, + const USER_CONF_RES & conf, + const USER_STAT_RES & stat, + SIMPLE::CALLBACK f, void * data); + int DelUser(const std::string & login, SIMPLE::CALLBACK f, void * data); + int AddUser(const std::string & login, + const USER_CONF_RES & conf, + const USER_STAT_RES & stat, + SIMPLE::CALLBACK f, void * data); + int AuthBy(const std::string & login, AUTH_BY::CALLBACK f, void * data); + int SendMessage(const std::string & login, const std::string & text, SIMPLE::CALLBACK f, void * data); + int CheckUser(const std::string & login, const std::string & password, SIMPLE::CALLBACK f, void * data); + + int GetServices(GET_CONTAINER::CALLBACK::TYPE f, void * data); + int GetService(const std::string & name, GET_SERVICE::CALLBACK f, void * data); + int ChgService(const SERVICE_CONF_RES & conf, SIMPLE::CALLBACK f, void * data); + int AddService(const std::string & name, + const SERVICE_CONF_RES & conf, + SIMPLE::CALLBACK f, void * data); + int DelService(const std::string & name, SIMPLE::CALLBACK f, void * data); + + int GetCorporations(GET_CONTAINER::CALLBACK::TYPE f, void * data); + int GetCorp(const std::string & name, GET_CORP::CALLBACK f, void * data); + int ChgCorp(const CORP_CONF_RES & conf, SIMPLE::CALLBACK f, void * data); + int AddCorp(const std::string & name, + const CORP_CONF_RES & conf, + SIMPLE::CALLBACK f, void * data); + int DelCorp(const std::string & name, SIMPLE::CALLBACK f, void * data); const std::string & GetStrError() const; - int Start(const char * el, const char ** attr); - void End(const char * el); private: - PARSER * currParser; - - PARSER_GET_USERS parserGetUsers; - PARSER_GET_USER parserGetUser; - PARSER_AUTH_BY parserAuthBy; - PARSER_SERVER_INFO parserServerInfo; - PARSER_CHG_USER parserChgUser; - PARSER_CHECK_USER parserCheckUser; - PARSER_SEND_MESSAGE parserSendMessage; - - NETTRANSACT nt; - - std::string errorMsg; - XML_Parser parser; - - RecvSendMessageCb_t RecvSendMessageCb; - - void * sendMessageDataCb; - - int Exec(const char * request); - - friend int AnsRecv(void * data, std::list * list); + class IMPL; + IMPL * pImpl; }; -//----------------------------------------------------------------------------- -#endif /* _SERVCONF_H_ */ +} // namespace STG + +#endif