X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/e9cb0683c0b33d8458c1d9b2558bbeb5d101e680..8e4002dc82b45344b2f8d90000d10eb9a904b1bc:/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 b422f708..094524e9 100644 --- a/stglibs/srvconf.lib/include/stg/servconf.h +++ b/stglibs/srvconf.lib/include/stg/servconf.h @@ -46,9 +46,6 @@ #include -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) @@ -60,31 +57,19 @@ struct ADMINDATA 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 SetSendMessageCallback(PARSER_SEND_MESSAGE::CALLBACK f, void * data); - - int GetUsers(); - int GetUser(const char * login); - int ChgUser(const char * request); - int AuthBy(const char * login); - int SendMessage(const char * request); - 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); + + 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); const std::string & GetStrError() const; - int Start(const char * el, const char ** attr); + void Start(const char * el, const char ** attr); void End(const char * el); private: @@ -103,9 +88,9 @@ private: std::string errorMsg; XML_Parser parser; - int Exec(const char * request); + int Exec(const std::string & request, PARSER & cp); - friend int AnsRecv(void * data, std::list * list); + friend bool AnsRecv(void * data, const std::string & chunk, bool final); }; //-----------------------------------------------------------------------------