- }
-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_PTR 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->GetProperty().password.ModificationTime() > lastUserUpdateTime)
- {
- if (currAdmin->GetPriv()->userConf || currAdmin->GetPriv()->userPasswd)
- s = "<password value=\"" + u->GetProperty().password.Get() + "\" />";
- else
- s = "<password value=\"++++++\"/>";
- middle += s;
- }
-
-
- if (u->GetProperty().cash.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<cash value=\"%f\" />", u->GetProperty().cash.Get());
- middle += s;
- //printfd(__FILE__, "cash value=\"%f\"\n", u->GetProperty().cash.Get());
- }
-
-
- if (u->GetProperty().freeMb.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<freemb value=\"%f\" />", u->GetProperty().freeMb.Get());
- middle += s;
- }
-
- if (u->GetProperty().credit.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<credit value=\"%f\" />", u->GetProperty().credit.Get());
- middle += s;
- }
-
- if (u->GetProperty().nextTariff.Get() != "")
- {
- if (u->GetProperty().tariffName.ModificationTime() > lastUserUpdateTime
- || u->GetProperty().nextTariff.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<tariff value=\"%s/%s\" />",
- u->GetProperty().tariffName.Get().c_str(),
- u->GetProperty().nextTariff.Get().c_str());
- middle += s;
- }
- }
- else
- {
- if (u->GetProperty().tariffName.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<tariff value=\"%s\" />",
- u->GetProperty().tariffName.Get().c_str());
- middle += s;
- }
- }
-
- if (u->GetProperty().note.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->GetProperty().note);
- strprintf(&s, "<note value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->GetProperty().phone.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->GetProperty().phone);
- strprintf(&s, "<phone value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->GetProperty().address.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->GetProperty().address);
- strprintf(&s, "<address value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->GetProperty().email.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->GetProperty().email);
- strprintf(&s, "<email value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- vector<USER_PROPERTY_LOGGED<string> *> userdata;
- userdata.push_back(u->GetProperty().userdata0.GetPointer());
- userdata.push_back(u->GetProperty().userdata1.GetPointer());
- userdata.push_back(u->GetProperty().userdata2.GetPointer());
- userdata.push_back(u->GetProperty().userdata3.GetPointer());
- userdata.push_back(u->GetProperty().userdata4.GetPointer());
- userdata.push_back(u->GetProperty().userdata5.GetPointer());
- userdata.push_back(u->GetProperty().userdata6.GetPointer());
- userdata.push_back(u->GetProperty().userdata7.GetPointer());
- userdata.push_back(u->GetProperty().userdata8.GetPointer());
- userdata.push_back(u->GetProperty().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->GetProperty().realName.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->GetProperty().realName);
- strprintf(&s, "<name value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->GetProperty().group.ModificationTime() > lastUserUpdateTime)
- {
- Encode12str(enc, u->GetProperty().group);
- strprintf(&s, "<GROUP value=\"%s\" />", enc.c_str());
- middle += s;
- }
-
- if (u->GetProperty().alwaysOnline.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<aonline value=\"%d\" />", u->GetProperty().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->GetProperty().ips.ModificationTime() > lastUserUpdateTime)
- {
- stringstream sstr;
- sstr << u->GetProperty().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->GetProperty().down.Get();
- upload = u->GetProperty().up.Get();
- traffMiddle = "";
-
- if (u->GetProperty().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->GetProperty().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->GetProperty().disabled.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<down value=\"%d\" />", u->GetProperty().disabled.Get());
- middle += s;
- }
-
- if (u->GetProperty().disabledDetailStat.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<DisableDetailStat value=\"%d\" />", u->GetProperty().disabledDetailStat.Get());
- middle += s;
- }
-
- //printfd(__FILE__, ">>>>> %s\n", s.c_str());
-
- if (u->GetProperty().passive.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<passive value=\"%d\" />", u->GetProperty().passive.Get());
- middle += s;
- }
-
- if (u->GetProperty().lastCashAdd.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<LastCash value=\"%f\" />", u->GetProperty().lastCashAdd.Get());
- middle += s;
- }
-
- if (u->GetProperty().lastCashAddTime.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<LastTimeCash value=\"%ld\" />", u->GetProperty().lastCashAddTime.Get());
- middle += s;
- }
-
-
- if (u->GetProperty().lastActivityTime.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<LastActivityTime value=\"%ld\" />", u->GetProperty().lastActivityTime.Get());
- middle += s;
- }
-
- if (u->GetProperty().creditExpire.ModificationTime() > lastUserUpdateTime)
- {
- strprintf(&s, "<CreditExpire value=\"%ld\" />", u->GetProperty().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_PTR 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;
-
-delete ucr;
-
-delete[] upr;
-
-delete[] downr;
-
-usr = new USER_STAT_RES;
-ucr = new USER_CONF_RES;
-
-upr = new RESETABLE<uint64_t>[DIR_NUM];
-downr = new RESETABLE<uint64_t>[DIR_NUM];
-};
-//-----------------------------------------------------------------------------
-string PARSER_CHG_USER::EncChar2String(const char * strEnc)
-{
-string str;
-Decode21str(str, strEnc);
-return str;
-}
-//-----------------------------------------------------------------------------
-int PARSER_CHG_USER::ParseStart(void *, const char *el, const char **attr)
-{
-depth++;
-
-if (depth == 1)
- {
- if (strcasecmp(el, "SetUser") == 0)
- {
- return 0;
- }
- }
-else
- {
- //printfd(__FILE__, "el=%s\n", el);
- if (strcasecmp(el, "login") == 0)
- {
- login = attr[1];
- return 0;
- }
-
- if (strcasecmp(el, "ip") == 0)
- {
- try
- {
- ucr->ips = StrToIPS(attr[1]);
- }
- catch (...)
- {
- printfd(__FILE__, "StrToIPS Error!\n");
- }
- }
-
- if (strcasecmp(el, "password") == 0)
- {
- ucr->password = attr[1];
- return 0;
- }
-
- if (strcasecmp(el, "address") == 0)
- {
- ucr->address = EncChar2String(attr[1]);
- return 0;
- }
-
- if (strcasecmp(el, "aonline") == 0)
- {
- ucr->alwaysOnline = (*(attr[1]) != '0');
- return 0;
- }
-
- if (strcasecmp(el, "cash") == 0)
- {
- if (attr[2] && (strcasecmp(attr[2], "msg") == 0))
- {
- cashMsg = EncChar2String(attr[3]);
- }
-
- double cash;
- if (strtodouble2(attr[1], cash) == 0)
- usr->cash = cash;
-
- if (strcasecmp(attr[0], "set") == 0)
- cashMustBeAdded = false;
-
- if (strcasecmp(attr[0], "add") == 0)
- cashMustBeAdded = true;
-
- return 0;
- }
-
- if (strcasecmp(el, "CreditExpire") == 0)
- {
- long int creditExpire = 0;
- if (str2x(attr[1], creditExpire) == 0)
- ucr->creditExpire = (time_t)creditExpire;
-
- return 0;
- }
-
- if (strcasecmp(el, "credit") == 0)
- {
- double credit;
- if (strtodouble2(attr[1], credit) == 0)
- ucr->credit = credit;
- return 0;
- }
-
- if (strcasecmp(el, "freemb") == 0)
- {
- double freeMb;
- if (strtodouble2(attr[1], freeMb) == 0)
- usr->freeMb = freeMb;
- return 0;
- }
-
- if (strcasecmp(el, "down") == 0)
- {
- int down = 0;
- if (str2x(attr[1], down) == 0)
- ucr->disabled = down;
- return 0;
- }
-
- if (strcasecmp(el, "DisableDetailStat") == 0)
- {
- int disabledDetailStat = 0;
- if (str2x(attr[1], disabledDetailStat) == 0)
- ucr->disabledDetailStat = disabledDetailStat;
- return 0;
- }
-
- if (strcasecmp(el, "email") == 0)
- {
- ucr->email = EncChar2String(attr[1]);
- return 0;
- }
-
- for (int i = 0; i < USERDATA_NUM; i++)
- {
- char name[15];
- sprintf(name, "userdata%d", i);
- if (strcasecmp(el, name) == 0)
- {
- ucr->userdata[i] = EncChar2String(attr[1]);
- return 0;
- }
- }
-
- if (strcasecmp(el, "group") == 0)
- {
- ucr->group = EncChar2String(attr[1]);
- return 0;
- }
-
- if (strcasecmp(el, "note") == 0)
- {
- ucr->note = EncChar2String(attr[1]);
- return 0;
- }
-
- if (strcasecmp(el, "passive") == 0)
- {
- int passive = 0;
- if (str2x(attr[1], passive) == 0)
- ucr->passive = passive;
- return 0;
- }
-
- if (strcasecmp(el, "phone") == 0)
- {
- ucr->phone = EncChar2String(attr[1]);
- return 0;
- }
-
- if (strcasecmp(el, "Name") == 0)
- {
- ucr->realName = EncChar2String(attr[1]);
- return 0;
- }
-
- if (strcasecmp(el, "traff") == 0)
- {
- int j = 0;
- int dir;
- DIR_TRAFF dtu;
- DIR_TRAFF dtd;
- unsigned long long t = 0;
- while (attr[j])
- {
- dir = attr[j][2] - '0';
-
- if (strncasecmp(attr[j], "md", 2) == 0)
- {
- str2x(attr[j+1], t);
- dtd[dir] = t;
- downr[dir] = t;
- }
- if (strncasecmp(attr[j], "mu", 2) == 0)
- {
- str2x(attr[j+1], t);
- dtu[dir] = t;
- upr[dir] = t;
- }
- j+=2;
- }
- usr->down = dtd;
- usr->up = dtu;
- return 0;
- }
-
- if (strcasecmp(el, "tariff") == 0)
- {
- if (strcasecmp(attr[0], "now") == 0)
- ucr->tariffName = attr[1];
-
- if (strcasecmp(attr[0], "delayed") == 0)
- ucr->nextTariff = attr[1];
-
- return 0;
- }
- }
-return -1;
-}
-//-----------------------------------------------------------------------------
-int PARSER_CHG_USER::ParseEnd(void *, const char *el)
-{
-if (depth == 1)
- {
- if (strcasecmp(el, "SetUser") == 0)
- {
- AplayChanges();
- CreateAnswer();
- depth--;
- return 0;
- }
- }
-
-depth--;
-return -1;
-}
-//-----------------------------------------------------------------------------
-void PARSER_CHG_USER::CreateAnswer()
-{
-//answerList->clear();
-answerList->erase(answerList->begin(), answerList->end());
-
-switch (res)
- {
- case 0:
- answerList->push_back("<SetUser result=\"ok\"/>");
- break;
- case -1:
- answerList->push_back("<SetUser result=\"error\"/>");
- break;
- case -2:
- answerList->push_back("<SetUser result=\"error\"/>");
- break;
- default:
- answerList->push_back("<SetUser result=\"error\"/>");
- break;
- }
-
-}
-//-----------------------------------------------------------------------------
-int PARSER_CHG_USER::AplayChanges()
-{
-USER_PTR u;
-
-res = 0;
-if (users->FindByName(login, &u))
- {
- res = -1;
- return -1;
- }
-
-if (!ucr->ips.res_empty())
- if (!u->GetProperty().ips.Set(ucr->ips.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->address.res_empty())
- if (!u->GetProperty().address.Set(ucr->address.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->alwaysOnline.res_empty())
- if (!u->GetProperty().alwaysOnline.Set(ucr->alwaysOnline.const_data(),
- currAdmin, login, store))
- res = -1;
-
-if (!ucr->creditExpire.res_empty())
- if (!u->GetProperty().creditExpire.Set(ucr->creditExpire.const_data(),
- currAdmin, login, store))
- res = -1;
-
-if (!ucr->credit.res_empty())
- if (!u->GetProperty().credit.Set(ucr->credit.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!usr->freeMb.res_empty())
- if (!u->GetProperty().freeMb.Set(usr->freeMb.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->disabled.res_empty())
- if (!u->GetProperty().disabled.Set(ucr->disabled.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->disabledDetailStat.res_empty())
- if (!u->GetProperty().disabledDetailStat.Set(ucr->disabledDetailStat.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->email.res_empty())
- if (!u->GetProperty().email.Set(ucr->email.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->group.res_empty())
- if (!u->GetProperty().group.Set(ucr->group.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->note.res_empty())
- if (!u->GetProperty().note.Set(ucr->note.const_data(), currAdmin, login, store))
- res = -1;
-
-vector<USER_PROPERTY_LOGGED<string> *> userdata;
-userdata.push_back(u->GetProperty().userdata0.GetPointer());
-userdata.push_back(u->GetProperty().userdata1.GetPointer());
-userdata.push_back(u->GetProperty().userdata2.GetPointer());
-userdata.push_back(u->GetProperty().userdata3.GetPointer());
-userdata.push_back(u->GetProperty().userdata4.GetPointer());
-userdata.push_back(u->GetProperty().userdata5.GetPointer());
-userdata.push_back(u->GetProperty().userdata6.GetPointer());
-userdata.push_back(u->GetProperty().userdata7.GetPointer());
-userdata.push_back(u->GetProperty().userdata8.GetPointer());
-userdata.push_back(u->GetProperty().userdata9.GetPointer());
-
-for (int i = 0; i < (int)userdata.size(); i++)
- {
- if (!ucr->userdata[i].res_empty())
- {
- if(!userdata[i]->Set(ucr->userdata[i].const_data(), currAdmin, login, store))
- res = -1;
- }
- }
-
-if (!ucr->passive.res_empty())
- if (!u->GetProperty().passive.Set(ucr->passive.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->password.res_empty())
- if (!u->GetProperty().password.Set(ucr->password.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->phone.res_empty())
- if (!u->GetProperty().phone.Set(ucr->phone.const_data(), currAdmin, login, store))
- res = -1;
-
-if (!ucr->realName.res_empty())
- if (!u->GetProperty().realName.Set(ucr->realName.const_data(), currAdmin, login, store))
- res = -1;
-
-
-if (!usr->cash.res_empty())
- {
- //if (*currAdmin->GetPriv()->userCash)
- {
- if (cashMustBeAdded)
- {
- if (!u->GetProperty().cash.Set(usr->cash.const_data() + u->GetProperty().cash,
- currAdmin,
- login,
- store,
- cashMsg))
- res = -1;
- }
- else
- {
- if (!u->GetProperty().cash.Set(usr->cash.const_data(), currAdmin, login, store, cashMsg))
- res = -1;
- }
- }
- }
-
-
-if (!ucr->tariffName.res_empty())
- {
- if (tariffs->FindByName(ucr->tariffName.const_data()))
- {
- if (!u->GetProperty().tariffName.Set(ucr->tariffName.const_data(), currAdmin, login, store))
- res = -1;
- u->ResetNextTariff();
- }
- else
- {
- //WriteServLog("SetUser: Tariff %s not found", ud.conf.tariffName.c_str());
- res = -1;
- }
- }
-
-if (!ucr->nextTariff.res_empty())
- {
- if (tariffs->FindByName(ucr->nextTariff.const_data()))
- {
- if (!u->GetProperty().nextTariff.Set(ucr->nextTariff.const_data(), currAdmin, login, store))
- res = -1;
- }
- else
- {
- //WriteServLog("SetUser: Tariff %s not found", ud.conf.tariffName.c_str());
- res = -1;
- }
- }
-
-DIR_TRAFF up = u->GetProperty().up;
-DIR_TRAFF down = u->GetProperty().down;
-int upCount = 0;
-int downCount = 0;
-for (int i = 0; i < DIR_NUM; i++)
- {
- if (!upr[i].res_empty())
- {
- up[i] = upr[i];
- upCount++;
- }
- if (!downr[i].res_empty())
- {
- down[i] = downr[i];
- downCount++;
- }
- }
-
-if (upCount)
- if (!u->GetProperty().up.Set(up, currAdmin, login, store))
- res = -1;
-
-if (downCount)
- if (!u->GetProperty().down.Set(down, currAdmin, login, store))
- res = -1;
-
-/*if (!usr->down.res_empty())
- {
- u->GetProperty().down.Set(usr->down.const_data(), currAdmin, login, store);
- }
-if (!usr->up.res_empty())
- {
- u->GetProperty().up.Set(usr->up.const_data(), currAdmin, login, store);
- }*/
-
-u->WriteConf();
-u->WriteStat();