X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/0093be0eb4dbe201a7d63da1de47f98c68987b1d..2da962edada912d8081f7e15db0ac887b98b179e:/stglibs/srvconf.lib/include/stg/servconf.h diff --git a/stglibs/srvconf.lib/include/stg/servconf.h b/stglibs/srvconf.lib/include/stg/servconf.h index 094524e9..0f5292d9 100644 --- a/stglibs/srvconf.lib/include/stg/servconf.h +++ b/stglibs/srvconf.lib/include/stg/servconf.h @@ -24,74 +24,48 @@ $Author: faust $ */ -#ifndef SERVCONF_H -#define SERVCONF_H +#ifndef __STG_STGLIBS_SERVCONF_H__ +#define __STG_STGLIBS_SERVCONF_H__ -#include "netunit.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/parser_send_message.h" +#include "stg/servconf_types.h" +#include "stg/admin_conf.h" #include "stg/os_int.h" -#include "stg/const.h" -#include -#include #include -#include - -#define MAX_ERR_STR_LEN (64) -#define IP_STRING_LEN (255) - -struct ADMINDATA +namespace STG { - char login[ADM_LOGIN_LEN]; -}; -//----------------------------------------------------------------------------- + class SERVCONF { public: SERVCONF(const std::string & server, uint16_t port, const std::string & login, const std::string & password); + ~SERVCONF(); - int GetUsers(PARSER_GET_USERS::CALLBACK f, void * data); - int GetUser(const std::string & login, PARSER_GET_USER::CALLBACK f, void * data); - int ChgUser(const std::string & request, PARSER_CHG_USER::CALLBACK f, void * data); - int AuthBy(const std::string & login, PARSER_AUTH_BY::CALLBACK f, void * data); - int SendMessage(const std::string & request, PARSER_SEND_MESSAGE::CALLBACK f, void * data); - int ServerInfo(PARSER_SERVER_INFO::CALLBACK f, void * data); - int CheckUser(const std::string & login, const std::string & password, PARSER_CHECK_USER::CALLBACK f, void * data); + int ServerInfo(SERVER_INFO::CALLBACK f, void * data); - const std::string & GetStrError() const; - void Start(const char * el, const char ** attr); - void End(const char * el); + int GetAdmins(GET_ADMINS::CALLBACK f, void * data); + int GetAdmin(const std::string & login, GET_ADMIN::CALLBACK f, void * data); + int ChgAdmin(const std::string & login, const ADMIN_CONF_RES & conf, CHG_ADMIN::CALLBACK f, void * data); + int AddAdmin(const std::string & login, const ADMIN_CONF & conf, GET_ADMIN::CALLBACK f, void * data); + int DelAdmin(const std::string & login, DEL_ADMIN::CALLBACK f, void * data); -private: - PARSER * currParser; + int GetUsers(GET_USERS::CALLBACK f, void * data); + int GetUser(const std::string & login, GET_USER::CALLBACK f, void * data); + int ChgUser(const std::string & request, CHG_USER::CALLBACK f, void * data); + int AuthBy(const std::string & login, AUTH_BY::CALLBACK f, void * data); + int SendMessage(const std::string & request, SEND_MESSAGE::CALLBACK f, void * data); + int CheckUser(const std::string & login, const std::string & password, CHECK_USER::CALLBACK f, void * data); - 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; - - int Exec(const std::string & request, PARSER & cp); + const std::string & GetStrError() const; - friend bool AnsRecv(void * data, const std::string & chunk, bool final); +private: + class IMPL; + IMPL * pImpl; }; -//----------------------------------------------------------------------------- -#endif /* _SERVCONF_H_ */ +} // namespace STG + +#endif