-#define UNAME_LEN (256)
-//-----------------------------------------------------------------------------
-// GET SERVER INFO
-//-----------------------------------------------------------------------------
-int PARSER_GET_SERVER_INFO::ParseStart(void *, const char *el, const char **)
-{
-answerList->erase(answerList->begin(), answerList->end());
-if (strcasecmp(el, "GetServerInfo") == 0)
- {
- return 0;
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-int PARSER_GET_SERVER_INFO::ParseEnd(void *, const char *el)
-{
-if (strcasecmp(el, "GetServerInfo") == 0)
- {
- CreateAnswer();
- return 0;
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-void PARSER_GET_SERVER_INFO::CreateAnswer()
-{
-char s[UNAME_LEN + 128];
-char un[UNAME_LEN];
-struct utsname utsn;
-
-uname(&utsn);
-un[0] = 0;
-
-strcat(un, utsn.sysname);
-strcat(un, " ");
-strcat(un, utsn.release);
-strcat(un, " ");
-strcat(un, utsn.machine);
-strcat(un, " ");
-strcat(un, utsn.nodename);
-
-//answerList->clear();
-answerList->erase(answerList->begin(), answerList->end());
-answerList->push_back("<ServerInfo>");
-
-sprintf(s, "<version value=\"%s\"/>", SERVER_VERSION);
-answerList->push_back(s);
-
-sprintf(s, "<tariff_num value=\"%d\"/>", tariffs->GetTariffsNum());
-answerList->push_back(s);
-
-sprintf(s, "<tariff value=\"%d\"/>", 2);
-answerList->push_back(s);
-
-sprintf(s, "<users_num value=\"%d\"/>", users->GetUserNum());
-answerList->push_back(s);
-
-sprintf(s, "<uname value=\"%s\"/>", un);
-answerList->push_back(s);
-
-sprintf(s, "<dir_num value=\"%d\"/>", DIR_NUM);
-answerList->push_back(s);
-
-sprintf(s, "<day_fee value=\"%d\"/>", settings->GetDayFee());
-answerList->push_back(s);
-
-for (int i = 0; i< DIR_NUM; i++)
- {
- string dn2e;
- Encode12str(dn2e, settings->GetDirName(i));
- sprintf(s, "<dir_name_%d value=\"%s\"/>", i, dn2e.c_str());
- answerList->push_back(s);
- }
-
-answerList->push_back("</ServerInfo>");
-}
-//-----------------------------------------------------------------------------
-// GET USER
-//-----------------------------------------------------------------------------
-PARSER_GET_USER::PARSER_GET_USER()
-{
-
-}
-//-----------------------------------------------------------------------------
-int PARSER_GET_USER::ParseStart(void *, const char *el, const char **attr)
-{
-if (strcasecmp(el, "GetUser") == 0)
- {
- if (attr[0] && attr[1])
- login = attr[1];
- else
- {
- //login.clear();
- login.erase(login.begin(), login.end());
- return -1;
- }
- return 0;
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-int PARSER_GET_USER::ParseEnd(void *, const char *el)
-{
-if (strcasecmp(el, "GetUser") == 0)
- {
- CreateAnswer();
- return 0;
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-void PARSER_GET_USER::CreateAnswer()
-{
-string s;
-string enc;
-
-user_iter u;
-
-answerList->erase(answerList->begin(), answerList->end());
-
-if (users->FindByName(login, &u))
- {
- s = "<user result=\"error\"/>";
- answerList->push_back(s);
- return;
- }
-
-s = "<user result=\"ok\">";
-answerList->push_back(s);
-
-s = "<login value=\"" + u->GetLogin() + "\"/>";
-answerList->push_back(s);
-
-if (currAdmin.GetPriv()->userConf || currAdmin.GetPriv()->userPasswd)
- s = "<password value=\"" + u->property.password.Get() + "\" />";
-else
- s = "<password value=\"++++++\"/>";
-answerList->push_back(s);
-
-strprintf(&s, "<cash value=\"%f\" />", u->property.cash.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<freemb value=\"%f\" />", u->property.freeMb.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<credit value=\"%f\" />", u->property.credit.Get());
-answerList->push_back(s);
-
-if (u->property.nextTariff.Get() != "")
- {
- strprintf(&s, "<tariff value=\"%s/%s\" />",
- u->property.tariffName.Get().c_str(),
- u->property.nextTariff.Get().c_str());
- }
-else
- {
- strprintf(&s, "<tariff value=\"%s\" />",
- u->property.tariffName.Get().c_str());
- }
-
-answerList->push_back(s);
-
-Encode12str(enc, u->property.note);
-s = "<note value=\"" + enc + "\" />";
-answerList->push_back(s);
-
-Encode12str(enc, u->property.phone);
-s = "<phone value=\"" + enc + "\" />";
-answerList->push_back(s);
-
-Encode12str(enc, u->property.address);
-s = "<address value=\"" + enc + "\" />";
-answerList->push_back(s);
-
-Encode12str(enc, u->property.email);
-s = "<email value=\"" + enc + "\" />";
-answerList->push_back(s);
-
-
-vector<USER_PROPERTY_LOGGED<string> *> userdata;
-userdata.push_back(u->property.userdata0.GetPointer());
-userdata.push_back(u->property.userdata1.GetPointer());
-userdata.push_back(u->property.userdata2.GetPointer());
-userdata.push_back(u->property.userdata3.GetPointer());
-userdata.push_back(u->property.userdata4.GetPointer());
-userdata.push_back(u->property.userdata5.GetPointer());
-userdata.push_back(u->property.userdata6.GetPointer());
-userdata.push_back(u->property.userdata7.GetPointer());
-userdata.push_back(u->property.userdata8.GetPointer());
-userdata.push_back(u->property.userdata9.GetPointer());
-
-string tmpI;
-for (unsigned i = 0; i < userdata.size(); i++)
- {
- Encode12str(enc, userdata[i]->Get());
- s = "<UserData" + x2str(i, tmpI) + " value=\"" + enc + "\" />";
- answerList->push_back(s);
- }
-
-Encode12str(enc, u->property.realName);
-s = "<name value=\"" + enc + "\" />";
-answerList->push_back(s);
-
-Encode12str(enc, u->property.group);
-s = "<GROUP value=\"" + enc + "\" />";
-answerList->push_back(s);
-
-strprintf(&s, "<status value=\"%d\" />", u->GetConnected());
-answerList->push_back(s);
-
-strprintf(&s, "<aonline value=\"%d\" />", u->property.alwaysOnline.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<currip value=\"%s\" />", inet_ntostring(u->GetCurrIP()).c_str());
-answerList->push_back(s);
-
-strprintf(&s, "<PingTime value=\"%lu\" />", u->GetPingTime());
-answerList->push_back(s);
-
-stringstream sstr;
-sstr << u->property.ips.Get();
-strprintf(&s, "<ip value=\"%s\" />", sstr.str().c_str());
-answerList->push_back(s);
-
-char * ss;
-ss = new char[DIR_NUM*25*4 + 50];
-char st[50];
-sprintf(ss, "<traff");
-DIR_TRAFF upload;
-DIR_TRAFF download;
-download = u->property.down.Get();
-upload = u->property.up.Get();
-
-for (int j = 0; j < DIR_NUM; j++)
- {
- string s;
- x2str(upload[j], s);
- sprintf(st, " MU%d=\"%s\"", j, s.c_str());
- strcat(ss, st);
-
- x2str(download[j], s);
- sprintf(st, " MD%d=\"%s\"", j, s.c_str());
- strcat(ss, st);
-
- sprintf(st, " SU%d=\"0\"", j);
- strcat(ss, st);
-
- sprintf(st, " SD%d=\"0\"", j);
- strcat(ss, st);
- }
-strcat(ss, " />");
-answerList->push_back(ss);
-delete[] ss;
-
-strprintf(&s, "<down value=\"%d\" />", u->property.disabled.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<DisableDetailStat value=\"%d\" />", u->property.disabledDetailStat.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<passive value=\"%d\" />", u->property.passive.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<LastCash value=\"%f\" />", u->property.lastCashAdd.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<LastTimeCash value=\"%ld\" />", u->property.lastCashAddTime.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<LastActivityTime value=\"%ld\" />", u->property.lastActivityTime.Get());
-answerList->push_back(s);
-
-strprintf(&s, "<CreditExpire value=\"%ld\" />", u->property.creditExpire.Get());
-answerList->push_back(s);
-
-strprintf(&s, "</user>");
-answerList->push_back(s);
-}
-//-----------------------------------------------------------------------------
-// GET USERS
-//-----------------------------------------------------------------------------
-PARSER_GET_USERS::PARSER_GET_USERS()
- : lastUserUpdateTime(0),
- lastUpdateFound(false)
-{
-}
-//-----------------------------------------------------------------------------
-int PARSER_GET_USERS::ParseStart(void *, const char *el, const char ** attr)
-{
-/*if (attr && *attr && *(attr+1))
- {
- printfd(__FILE__, "attr=%s %s\n", *attr, *(attr+1));
- }
-else
- {
- printfd(__FILE__, "attr = NULL\n");
- }*/
-
-lastUpdateFound = false;
-if (strcasecmp(el, "GetUsers") == 0)
- {
- while (attr && *attr && *(attr+1))
- {
- if (strcasecmp(*attr, "LastUpdate") == 0)
- {
- if (str2x(*(attr+1), lastUserUpdateTime) == 0)
- {
- //printfd(__FILE__, "lastUserUpdateTime=%d\n", lastUserUpdateTime);
- lastUpdateFound = true;
- }
- else
- {
- //printfd(__FILE__, "NO lastUserUpdateTime\n");
- }
- }
- ++attr;
- }
-
- return 0;
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-int PARSER_GET_USERS::ParseEnd(void *, const char *el)
-{
-if (strcasecmp(el, "GetUsers") == 0)
- {
- CreateAnswer();
- return 0;
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-void PARSER_GET_USERS::CreateAnswer()
-{
-answerList->erase(answerList->begin(), answerList->end());
-
-string s;
-string userStart;
-string traffStart;
-string traffMiddle;
-string traffFinish;
-string middle;
-string userFinish;
-
-
-string enc;
-
-user_iter u;
-
-int h = users->OpenSearch();
-if (!h)
- {
- printfd(__FILE__, "users->OpenSearch() error\n");
- users->CloseSearch(h);
- return;
- }
-string updateTime;
-x2str(time(NULL), updateTime);
-
-if (lastUpdateFound)
- answerList->push_back("<Users LastUpdate=\"" + updateTime + "\">");
-else
- answerList->push_back("<Users>");
-
-while (1)
- {
- if (users->SearchNext(h, &u))
- {
- break;
- }
- userStart = "<user login=\"" + u->GetLogin() + "\">";
- middle = "";
-
- if (u->property.password.ModificationTime() > lastUserUpdateTime)
- {
- if (currAdmin.GetPriv()->userConf || currAdmin.GetPriv()->userPasswd)
- s = "<password value=\"" + u->property.password.Get() + "\" />";
- else
- s = "<password value=\"++++++\"/>";
- middle += s;
- }
-
-
- if (u->property.cash.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<cash value=\"%f\" />", u->property.cash.Get());
- middle += s;
- //printfd(__FILE__, "cash value=\"%f\"\n", u->property.cash.Get());
- }
-
-
- if (u->property.freeMb.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<freemb value=\"%f\" />", u->property.freeMb.Get());
- middle += s;
- }
-
- if (u->property.credit.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<credit value=\"%f\" />", u->property.credit.Get());
- middle += s;
- }
-
- if (u->property.nextTariff.Get() != "")
- {
- if (u->property.tariffName.ModificationTime() > lastUserUpdateTime
- || u->property.nextTariff.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<tariff value=\"%s/%s\" />",
- u->property.tariffName.Get().c_str(),
- u->property.nextTariff.Get().c_str());
- middle += s;
- }
- }
- else
- {
- if (u->property.tariffName.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<tariff value=\"%s\" />",
- u->property.tariffName.Get().c_str());
- middle += s;
- }
- }
-
- if (u->property.note.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->property.note);
- strprintf(&s, "<note value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->property.phone.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->property.phone);
- strprintf(&s, "<phone value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->property.address.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->property.address);
- strprintf(&s, "<address value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->property.email.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->property.email);
- strprintf(&s, "<email value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- vector<USER_PROPERTY_LOGGED<string> *> userdata;
- userdata.push_back(u->property.userdata0.GetPointer());
- userdata.push_back(u->property.userdata1.GetPointer());
- userdata.push_back(u->property.userdata2.GetPointer());
- userdata.push_back(u->property.userdata3.GetPointer());
- userdata.push_back(u->property.userdata4.GetPointer());
- userdata.push_back(u->property.userdata5.GetPointer());
- userdata.push_back(u->property.userdata6.GetPointer());
- userdata.push_back(u->property.userdata7.GetPointer());
- userdata.push_back(u->property.userdata8.GetPointer());
- userdata.push_back(u->property.userdata9.GetPointer());
-
- string tmpI;
- for (unsigned i = 0; i < userdata.size(); i++)
- {
- if (userdata[i]->ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, userdata[i]->Get());
- s = "<UserData" + x2str(i, tmpI) + " value=\"" + enc + "\" />";
- middle += s;
- }
- }
-
- if (u->property.realName.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->property.realName);
- strprintf(&s, "<name value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->property.group.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->property.group);
- strprintf(&s, "<GROUP value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->property.alwaysOnline.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<aonline value=\"%d\" />", u->property.alwaysOnline.Get());
- middle += s;
- }
-
- if (u->GetCurrIPModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<currip value=\"%s\" />", inet_ntostring(u->GetCurrIP()).c_str());
- middle += s;
- }
-
-
- if (u->GetConnectedModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<status value=\"%d\" />", u->GetConnected());
- middle += s;
- }
-
- if (u->GetPingTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<PingTime value=\"%lu\" />", u->GetPingTime());
- middle += s;
- }
-
- if (u->property.ips.ModificationTime() > lastUserUpdateTime)
- {
- stringstream sstr;
- sstr << u->property.ips.Get();
- strprintf(&s, "<ip value=\"%s\" />", sstr.str().c_str());
- middle += s;
- }
-
- char st[50];
- traffStart = "<traff";
- DIR_TRAFF upload;
- DIR_TRAFF download;
- download = u->property.down.Get();
- upload = u->property.up.Get();
- traffMiddle = "";
-
- if (u->property.up.ModificationTime() > lastUserUpdateTime)
- {
- for (int j = 0; j < DIR_NUM; j++)
- {
- string s;
- x2str(upload[j], s);
- sprintf(st, " MU%d=\"%s\" ", j, s.c_str());
- traffMiddle += st;
- }
- }
-
- if (u->property.down.ModificationTime() > lastUserUpdateTime)
- {
- for (int j = 0; j < DIR_NUM; j++)
- {
- x2str(download[j], s);
- sprintf(st, " MD%d=\"%s\" ", j, s.c_str());
- traffMiddle += st;
- }
- }
-
- traffFinish = " />";
- if (traffMiddle.length() > 0)
- {
- middle += traffStart;
- middle += traffMiddle;
- middle += traffFinish;
- }
-
- if (u->property.disabled.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<down value=\"%d\" />", u->property.disabled.Get());
- middle += s;
- }
-
- if (u->property.disabledDetailStat.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<DisableDetailStat value=\"%d\" />", u->property.disabledDetailStat.Get());
- middle += s;
- }
-
- //printfd(__FILE__, ">>>>> %s\n", s.c_str());
-
- if (u->property.passive.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<passive value=\"%d\" />", u->property.passive.Get());
- middle += s;
- }
-
- if (u->property.lastCashAdd.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<LastCash value=\"%f\" />", u->property.lastCashAdd.Get());
- middle += s;
- }
-
- if (u->property.lastCashAddTime.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<LastTimeCash value=\"%ld\" />", u->property.lastCashAddTime.Get());
- middle += s;
- }
-
-
- if (u->property.lastActivityTime.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<LastActivityTime value=\"%ld\" />", u->property.lastActivityTime.Get());
- middle += s;
- }
-
- if (u->property.creditExpire.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<CreditExpire value=\"%ld\" />", u->property.creditExpire.Get());
- middle += s;
- }
-
-
- userFinish = "</user>";
-
- if (middle.length() > 0)
- {
- /*printfd(__FILE__, "login: %s\n", u->GetLogin().c_str());
- printfd(__FILE__, "middle: %s\n", middle.c_str());*/
-
- answerList->push_back(userStart);
- answerList->push_back(middle);
- answerList->push_back(userFinish);
- }
- }
-
-users->CloseSearch(h);
-
-//answerList->push_back("</Users>");
-
-answerList->push_back("</Users>");
-}
-//-----------------------------------------------------------------------------
-// ADD USER
-//-----------------------------------------------------------------------------
-PARSER_ADD_USER::PARSER_ADD_USER()
-{
-depth = 0;
-}
-//-----------------------------------------------------------------------------
-int PARSER_ADD_USER::ParseStart(void *, const char *el, const char **attr)
-{
-depth++;
-
-if (depth == 1)
- {
- if (strcasecmp(el, "AddUser") == 0)
- {
- return 0;
- }
- }
-else
- {
- if (strcasecmp(el, "login") == 0)
- {
- login = attr[1];
- return 0;
- }
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-int PARSER_ADD_USER::ParseEnd(void *, const char *el)
-{
-if (depth == 1)
- {
- if (strcasecmp(el, "AddUser") == 0)
- {
- CreateAnswer();
- depth--;
- return 0;
- }
- }
-
-depth--;
-return -1;
-}
-//-----------------------------------------------------------------------------
-void PARSER_ADD_USER::Reset()
-{
-BASE_PARSER::Reset();
-depth = 0;
-}
-//-----------------------------------------------------------------------------
-void PARSER_ADD_USER::CreateAnswer()
-{
-//answerList->clear();
-answerList->erase(answerList->begin(), answerList->end());
-
-if (CheckUserData() == 0)
- {
- answerList->push_back("<AddUser result=\"ok\"/>");
- }
-else
- {
- answerList->push_back("<AddUser result=\"error\" reason=\"Access denied\"/>");
- }
-}
-//-----------------------------------------------------------------------------
-int PARSER_ADD_USER::CheckUserData()
-{
-user_iter u;
-if (users->FindByName(login, &u))
- {
- return users->Add(login, currAdmin);
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-// PARSER CHG USER
-//-----------------------------------------------------------------------------
-PARSER_CHG_USER::PARSER_CHG_USER()
- : usr(NULL),
- ucr(NULL),
- upr(NULL),
- downr(NULL),
- cashMustBeAdded(false),
- res(0)
-{
-Reset();
-}
-//-----------------------------------------------------------------------------
-PARSER_CHG_USER::~PARSER_CHG_USER()
-{
-delete usr;
-delete ucr;
-delete[] upr;
-delete[] downr;
-}
-//-----------------------------------------------------------------------------
-void PARSER_CHG_USER::Reset()
-{
-depth = 0;
-delete usr;