X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/c65b73de5dfbbb54f7b977a9fcd72d1abbb1e827..95eb36dbbe208782ea9b93f45ba8955cfdd1a0d5:/projects/stargazer/plugins/configuration/sgconfig/parser_admins.cpp?ds=inline diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser_admins.cpp b/projects/stargazer/plugins/configuration/sgconfig/parser_admins.cpp index 01ae9e81..d59bd10f 100644 --- a/projects/stargazer/plugins/configuration/sgconfig/parser_admins.cpp +++ b/projects/stargazer/plugins/configuration/sgconfig/parser_admins.cpp @@ -16,13 +16,12 @@ /* * Author : Boris Mikhailenko <stg34@stargazer.dp.ua> - * Author : Maxim Mamontov <faust@stargazer.dp.ua> + * Author : Maksym Mamontov <stg@madf.info> */ #include "parser_admins.h" #include "stg/admins.h" -#include "stg/common.h" #include <strings.h> // strcasecmp @@ -31,6 +30,11 @@ using STG::PARSER::ADD_ADMIN; using STG::PARSER::DEL_ADMIN; using STG::PARSER::CHG_ADMIN; +const char * GET_ADMINS::tag = "GetAdmins"; +const char * ADD_ADMIN::tag = "AddAdmin"; +const char * DEL_ADMIN::tag = "DelAdmin"; +const char * CHG_ADMIN::tag = "ChgAdmin"; + void GET_ADMINS::CreateAnswer() { const PRIV * priv = m_currAdmin.GetPriv(); @@ -40,9 +44,7 @@ void GET_ADMINS::CreateAnswer() return; } - m_answer.clear(); - - m_answer += GetOpenTag(); + m_answer = "<Admins>"; ADMIN_CONF ac; int h = m_admins.OpenSearch(); @@ -58,14 +60,14 @@ void GET_ADMINS::CreateAnswer() m_answer += "<admin login=\"" + ac.login + "\" priv=\"" + x2str(p) + "\"/>"; } m_admins.CloseSearch(h); - m_answer += GetCloseTag(); + m_answer += "</Admins>"; } int DEL_ADMIN::Start(void *, const char * el, const char ** attr) { if (strcasecmp(el, m_tag.c_str()) == 0) { - admin = attr[1]; + m_admin = attr[1]; return 0; } return -1; @@ -73,7 +75,7 @@ int DEL_ADMIN::Start(void *, const char * el, const char ** attr) void DEL_ADMIN::CreateAnswer() { - if (m_admins.Del(admin, &m_currAdmin) == 0) + if (m_admins.Del(m_admin, &m_currAdmin) == 0) m_answer = "<" + m_tag + " Result=\"Ok\"/>"; else m_answer = "<" + m_tag + " Result=\"Error. " + m_admins.GetStrError() + "\"/>"; @@ -83,7 +85,7 @@ int ADD_ADMIN::Start(void *, const char *el, const char **attr) { if (strcasecmp(el, m_tag.c_str()) == 0) { - admin = attr[1]; + m_admin = attr[1]; return 0; } return -1; @@ -91,7 +93,7 @@ int ADD_ADMIN::Start(void *, const char *el, const char **attr) void ADD_ADMIN::CreateAnswer() { - if (m_admins.Add(admin, &m_currAdmin) == 0) + if (m_admins.Add(m_admin, &m_currAdmin) == 0) m_answer = "<" + m_tag + " Result=\"Ok\"/>"; else m_answer = "<" + m_tag + " Result=\"Error. " + m_admins.GetStrError() + "\"/>";