X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/45eb432454451f078ca433c3aaf3c336598a74cb..46b0747592074017ff0ea4b33d4a7194235886e5:/projects/stargazer/plugins/configuration/rpcconfig/user_helper.cpp diff --git a/projects/stargazer/plugins/configuration/rpcconfig/user_helper.cpp b/projects/stargazer/plugins/configuration/rpcconfig/user_helper.cpp deleted file mode 100644 index 8e03c63a..00000000 --- a/projects/stargazer/plugins/configuration/rpcconfig/user_helper.cpp +++ /dev/null @@ -1,424 +0,0 @@ -#include "user_helper.h" - -#include "../../../tariffs.h" -#include "../../../admin.h" -#include "base_store.h" -#include "user_ips.h" -#include "utils.h" -#include "common.h" - -//------------------------------------------------------------------------------ - -void USER_HELPER::GetUserInfo(xmlrpc_c::value * info, - bool hidePassword) -{ -std::string enc; - -std::map structVal; - -structVal["result"] = xmlrpc_c::value_boolean(true); -structVal["login"] = xmlrpc_c::value_string(iter->GetLogin()); - -if (!hidePassword) - { - structVal["password"] = xmlrpc_c::value_string(iter->property.password.Get()); - } -else - { - structVal["password"] = xmlrpc_c::value_string("++++++++"); - } - -structVal["cash"] = xmlrpc_c::value_double(iter->property.cash.Get()); -structVal["freemb"] = xmlrpc_c::value_double(iter->property.freeMb.Get()); -structVal["credit"] = xmlrpc_c::value_double(iter->property.credit.Get()); - -if (iter->property.nextTariff.Get() != "") - { - structVal["tariff"] = xmlrpc_c::value_string( - iter->property.tariffName.Get() + - "/" + - iter->property.nextTariff.Get() - ); - } -else - { - structVal["tariff"] = xmlrpc_c::value_string(iter->property.tariffName.Get()); - } - -structVal["note"] = xmlrpc_c::value_string(IconvString(iter->property.note, "KOI8-R", "UTF-8")); - -structVal["phone"] = xmlrpc_c::value_string(IconvString(iter->property.phone, "KOI8-R", "UTF-8")); - -structVal["address"] = xmlrpc_c::value_string(IconvString(iter->property.address, "KOI8-R", "UTF-8")); - -structVal["email"] = xmlrpc_c::value_string(IconvString(iter->property.email, "KOI8-R", "UTF-8")); - -std::vector userdata; - -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata0.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata1.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata2.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata3.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata4.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata5.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata6.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata7.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata8.Get(), "KOI8-R", "UTF-8"))); -userdata.push_back(xmlrpc_c::value_string(IconvString(iter->property.userdata9.Get(), "KOI8-R", "UTF-8"))); - -structVal["userdata"] = xmlrpc_c::value_array(userdata); - -structVal["name"] = xmlrpc_c::value_string(IconvString(iter->property.realName, "KOI8-R", "UTF-8")); - -structVal["group"] = xmlrpc_c::value_string(IconvString(iter->property.group, "KOI8-R", "UTF-8")); - -structVal["status"] = xmlrpc_c::value_boolean(iter->GetConnected()); -structVal["aonline"] = xmlrpc_c::value_boolean(iter->property.alwaysOnline.Get()); -structVal["currip"] = xmlrpc_c::value_string(inet_ntostring(iter->GetCurrIP())); -structVal["pingtime"] = xmlrpc_c::value_int(iter->GetPingTime()); -structVal["ips"] = xmlrpc_c::value_string(iter->property.ips.Get().GetIpStr()); - -std::map traffInfo; -std::vector mu(DIR_NUM); -std::vector md(DIR_NUM); -std::vector su(DIR_NUM); -std::vector sd(DIR_NUM); - -DIR_TRAFF upload; -DIR_TRAFF download; -DIR_TRAFF supload; -DIR_TRAFF sdownload; -download = iter->property.down.Get(); -upload = iter->property.up.Get(); -sdownload = iter->GetSessionUpload(); -supload = iter->GetSessionDownload(); - -for (int j = 0; j < DIR_NUM; j++) - { - std::string value; - x2str(upload[j], value); - mu[j] = xmlrpc_c::value_string(value); - x2str(download[j], value); - md[j] = xmlrpc_c::value_string(value); - x2str(supload[j], value); - su[j] = xmlrpc_c::value_string(value); - x2str(sdownload[j], value); - sd[j] = xmlrpc_c::value_string(value); - } - -traffInfo["mu"] = xmlrpc_c::value_array(mu); -traffInfo["md"] = xmlrpc_c::value_array(md); -traffInfo["su"] = xmlrpc_c::value_array(su); -traffInfo["sd"] = xmlrpc_c::value_array(sd); - -structVal["traff"] = xmlrpc_c::value_struct(traffInfo); - -structVal["down"] = xmlrpc_c::value_boolean(iter->property.disabled.Get()); -structVal["disableddetailstat"] = xmlrpc_c::value_boolean(iter->property.disabledDetailStat.Get()); -structVal["passive"] = xmlrpc_c::value_boolean(iter->property.passive.Get()); -structVal["lastcash"] = xmlrpc_c::value_double(iter->property.lastCashAdd.Get()); -structVal["lasttimecash"] = xmlrpc_c::value_int(iter->property.lastCashAddTime.Get()); -structVal["lastactivitytime"] = xmlrpc_c::value_int(iter->property.lastActivityTime.Get()); -structVal["creditexpire"] = xmlrpc_c::value_int(iter->property.creditExpire.Get()); - -*info = xmlrpc_c::value_struct(structVal); -} - -//------------------------------------------------------------------------------ - -bool USER_HELPER::SetUserInfo(const xmlrpc_c::value & info, - const ADMIN & admin, - const std::string & login, - const BASE_STORE & store, - TARIFFS * tariffs) -{ -std::map structVal( - static_cast >(xmlrpc_c::value_struct(info)) - ); - -std::map::iterator it; - -if ((it = structVal.find("password")) != structVal.end()) - { - std::string value(xmlrpc_c::value_string(it->second)); - if (iter->property.password.Get() != value) - if (!iter->property.password.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("ips")) != structVal.end()) - { - USER_IPS ips; - ips = StrToIPS(xmlrpc_c::value_string(it->second)); - if (!iter->property.ips.Set(ips, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("address")) != structVal.end()) - { - std::string value(IconvString(xmlrpc_c::value_string(it->second), "UTF-8", "KOI8-R")); - if (iter->property.address.Get() != value) - if (!iter->property.address.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("phone")) != structVal.end()) - { - std::string value(IconvString(xmlrpc_c::value_string(it->second), "UTF-8", "KOI8-R")); - if (iter->property.phone.Get() != value) - if (!iter->property.phone.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("email")) != structVal.end()) - { - std::string value(IconvString(xmlrpc_c::value_string(it->second), "UTF-8", "KOI8-R")); - if (iter->property.email.Get() != value) - if (!iter->property.email.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("cash")) != structVal.end()) - { - double value(xmlrpc_c::value_double(it->second)); - if (iter->property.cash.Get() != value) - if (!iter->property.cash.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("creditexpire")) != structVal.end()) - { - time_t value(xmlrpc_c::value_int(it->second)); - if (iter->property.creditExpire.Get() != value) - if (!iter->property.creditExpire.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("credit")) != structVal.end()) - { - double value(xmlrpc_c::value_double(it->second)); - if (iter->property.credit.Get() != value) - if (!iter->property.credit.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("freemb")) != structVal.end()) - { - double value(xmlrpc_c::value_double(it->second)); - if (iter->property.freeMb.Get() != value) - if (!iter->property.freeMb.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("down")) != structVal.end()) - { - bool value(xmlrpc_c::value_boolean(it->second)); - if (iter->property.disabled.Get() != value) - if (!iter->property.disabled.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("passive")) != structVal.end()) - { - bool value(xmlrpc_c::value_boolean(it->second)); - if (iter->property.passive.Get() != value) - if (!iter->property.passive.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("aonline")) != structVal.end()) - { - bool value(xmlrpc_c::value_boolean(it->second)); - if (iter->property.alwaysOnline.Get() != value) - if (!iter->property.alwaysOnline.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("disableddetailstat")) != structVal.end()) - { - bool value(xmlrpc_c::value_boolean(it->second)); - if (iter->property.disabledDetailStat.Get() != value) - if (!iter->property.disabledDetailStat.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("name")) != structVal.end()) - { - std::string value(IconvString(xmlrpc_c::value_string(it->second), "UTF-8", "KOI8-R")); - if (iter->property.realName.Get() != value) - if (!iter->property.realName.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("group")) != structVal.end()) - { - std::string value(IconvString(xmlrpc_c::value_string(it->second), "UTF-8", "KOI8-R")); - if (iter->property.group.Get() != value) - if (!iter->property.group.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("note")) != structVal.end()) - { - std::string value(IconvString(xmlrpc_c::value_string(it->second), "UTF-8", "KOI8-R")); - if (iter->property.note.Get() != value) - if (!iter->property.note.Set(value, - admin, - login, - &store)) - return true; - } - -if ((it = structVal.find("userdata")) != structVal.end()) - { - std::vector *> userdata; - userdata.push_back(iter->property.userdata0.GetPointer()); - userdata.push_back(iter->property.userdata1.GetPointer()); - userdata.push_back(iter->property.userdata2.GetPointer()); - userdata.push_back(iter->property.userdata3.GetPointer()); - userdata.push_back(iter->property.userdata4.GetPointer()); - userdata.push_back(iter->property.userdata5.GetPointer()); - userdata.push_back(iter->property.userdata6.GetPointer()); - userdata.push_back(iter->property.userdata7.GetPointer()); - userdata.push_back(iter->property.userdata8.GetPointer()); - userdata.push_back(iter->property.userdata9.GetPointer()); - - std::vector udata( - xmlrpc_c::value_array(it->second).vectorValueValue() - ); - - for (unsigned i = 0; i < userdata.size(); ++i) - { - std::string value(IconvString(xmlrpc_c::value_string(udata[i]), "UTF-8", "KOI8-R")); - if (userdata[i]->Get() != value) - if (!userdata[i]->Set(value, - admin, - login, - &store)) - return true; - } - } - -if ((it = structVal.find("traff")) != structVal.end()) - { - std::map traff( - static_cast >(xmlrpc_c::value_struct(it->second)) - ); - - DIR_TRAFF dtData; - dtData = iter->property.up.Get(); - if ((it = traff.find("mu")) != traff.end()) - { - std::vector data(xmlrpc_c::value_array(it->second).vectorValueValue()); - - for (int i = 0; i < std::min(DIR_NUM, static_cast(data.size())); ++i) - { - int64_t value; - if (str2x(xmlrpc_c::value_string(data[i]), value)) - printfd(__FILE__, "USER_HELPER::SetUserInfo(): 'Invalid month upload value'\n"); - else - dtData[i] = value; - } - if (!iter->property.up.Set(dtData, - admin, - login, - &store)) - return true; - } - dtData = iter->property.down.Get(); - if ((it = traff.find("md")) != traff.end()) - { - std::vector data(xmlrpc_c::value_array(it->second).vectorValueValue()); - - for (int i = 0; i < std::min(DIR_NUM, static_cast(data.size())); ++i) - { - int64_t value; - if (str2x(xmlrpc_c::value_string(data[i]), value)) - printfd(__FILE__, "USER_HELPER::SetUserInfo(): 'Invalid month download value'\n"); - else - dtData[i] = value; - } - if (!iter->property.down.Set(dtData, - admin, - login, - &store)) - return true; - } - } - -if ((it = structVal.find("tariff")) != structVal.end()) - { - std::string tariff(xmlrpc_c::value_string(it->second)); - size_t pos = tariff.find('/'); - std::string nextTariff; - if (pos != std::string::npos) - { - nextTariff = tariff.substr(pos + 1); - tariff = tariff.substr(0, pos); - } - - if (tariffs->FindByName(tariff)) - if (iter->property.tariffName.Get() != tariff) - if (!iter->property.tariffName.Set(tariff, - admin, - login, - &store)) - return true; - - if (nextTariff != "" && - tariffs->FindByName(nextTariff)) - if (iter->property.nextTariff.Get() != nextTariff) - if (!iter->property.nextTariff.Set(tariff, - admin, - login, - &store)) - return true; - } - -return false; -}