#include <cerrno>
#include <sstream>
+#include "stg/version.h"
+#include "stg/tariffs.h"
+#include "stg/user_property.h"
+#include "stg/settings.h"
+#include "stg/logger.h"
#include "parser.h"
-#include "version.h"
-#include "tariffs.h"
-#include "../../../settings.h"
-#include "../../../user_property.h"
#define UNAME_LEN (256)
//-----------------------------------------------------------------------------
sprintf(s, "<version value=\"%s\"/>", SERVER_VERSION);
answerList->push_back(s);
-sprintf(s, "<tariff_num value=\"%d\"/>", tariffs->GetTariffsNum());
+sprintf(s, "<tariff_num value=\"%llu\"/>", (unsigned long long)tariffs->Count());
answerList->push_back(s);
sprintf(s, "<tariff value=\"%d\"/>", 2);
answerList->push_back(s);
-sprintf(s, "<users_num value=\"%d\"/>", users->GetUserNum());
+sprintf(s, "<users_num value=\"%llu\"/>", (unsigned long long)users->Count());
answerList->push_back(s);
sprintf(s, "<uname value=\"%s\"/>", un);
//-----------------------------------------------------------------------------
// 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)
//-----------------------------------------------------------------------------
// 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))
//-----------------------------------------------------------------------------
// ADD USER
//-----------------------------------------------------------------------------
-PARSER_ADD_USER::PARSER_ADD_USER()
-{
-depth = 0;
-}
-//-----------------------------------------------------------------------------
int PARSER_ADD_USER::ParseStart(void *, const char *el, const char **attr)
{
depth++;
USER_PTR u;
if (users->FindByName(login, &u))
{
- return users->Add(login, *currAdmin);
+ return users->Add(login, currAdmin);
}
return -1;
}
// PARSER CHG USER
//-----------------------------------------------------------------------------
PARSER_CHG_USER::PARSER_CHG_USER()
- : usr(NULL),
+ : BASE_PARSER(),
+ usr(NULL),
ucr(NULL),
upr(NULL),
downr(NULL),
+ cashMsg(),
+ login(),
cashMustBeAdded(false),
res(0)
{
//-----------------------------------------------------------------------------
int PARSER_CHG_USER::AplayChanges()
{
+printfd(__FILE__, "PARSER_CHG_USER::AplayChanges()\n");
USER_PTR u;
res = 0;
return -1;
}
+bool check = false;
+bool alwaysOnline = u->GetProperty().alwaysOnline;
+if (!ucr->alwaysOnline.res_empty())
+ {
+ check = true;
+ alwaysOnline = ucr->alwaysOnline.const_data();
+ }
+bool onlyOneIP = u->GetProperty().ips.ConstData().OnlyOneIP();
if (!ucr->ips.res_empty())
- if (!u->GetProperty().ips.Set(ucr->ips.const_data(), *currAdmin, login, store))
- res = -1;
+ {
+ check = true;
+ onlyOneIP = ucr->ips.const_data().OnlyOneIP();
+ }
-if (!ucr->address.res_empty())
- if (!u->GetProperty().address.Set(ucr->address.const_data(), *currAdmin, login, store))
+if (check && alwaysOnline && !onlyOneIP)
+ {
+ printfd(__FILE__, "Requested change leads to a forbidden state: AlwaysOnline with multiple IP's\n");
+ GetStgLogger()("%s Requested change leads to a forbidden state: AlwaysOnline with multiple IP's", currAdmin->GetLogStr().c_str());
+ return -1;
+ }
+
+if (!ucr->ips.res_empty())
+ if (!u->GetProperty().ips.Set(ucr->ips.const_data(), currAdmin, login, store))
res = -1;
if (!ucr->alwaysOnline.res_empty())
if (!u->GetProperty().alwaysOnline.Set(ucr->alwaysOnline.const_data(),
- *currAdmin, login, store))
+ 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->creditExpire.res_empty())
if (!u->GetProperty().creditExpire.Set(ucr->creditExpire.const_data(),
- *currAdmin, login, store))
+ currAdmin, login, store))
res = -1;
if (!ucr->credit.res_empty())
- if (!u->GetProperty().credit.Set(ucr->credit.const_data(), *currAdmin, login, store))
+ 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))
+ 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))
+ 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))
+ 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))
+ 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))
+ 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))
+ if (!u->GetProperty().note.Set(ucr->note.const_data(), currAdmin, login, store))
res = -1;
vector<USER_PROPERTY_LOGGED<string> *> userdata;
{
if (!ucr->userdata[i].res_empty())
{
- if(!userdata[i]->Set(ucr->userdata[i].const_data(), *currAdmin, login, store))
+ 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))
+ 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))
+ 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))
+ 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))
+ if (!u->GetProperty().realName.Set(ucr->realName.const_data(), currAdmin, login, store))
res = -1;
if (cashMustBeAdded)
{
if (!u->GetProperty().cash.Set(usr->cash.const_data() + u->GetProperty().cash,
- *currAdmin,
- login,
- store,
- cashMsg))
+ currAdmin,
+ login,
+ store,
+ cashMsg))
res = -1;
}
else
{
- if (!u->GetProperty().cash.Set(usr->cash.const_data(), *currAdmin, login, store, cashMsg))
+ if (!u->GetProperty().cash.Set(usr->cash.const_data(), currAdmin, login, store, cashMsg))
res = -1;
}
}
{
if (tariffs->FindByName(ucr->tariffName.const_data()))
{
- if (!u->GetProperty().tariffName.Set(ucr->tariffName.const_data(), *currAdmin, login, store))
+ if (!u->GetProperty().tariffName.Set(ucr->tariffName.const_data(), currAdmin, login, store))
res = -1;
u->ResetNextTariff();
}
{
if (tariffs->FindByName(ucr->nextTariff.const_data()))
{
- if (!u->GetProperty().nextTariff.Set(ucr->nextTariff.const_data(), *currAdmin, login, store))
+ if (!u->GetProperty().nextTariff.Set(ucr->nextTariff.const_data(), currAdmin, login, store))
res = -1;
}
else
}
if (upCount)
- if (!u->GetProperty().up.Set(up, *currAdmin, login, store))
+ if (!u->GetProperty().up.Set(up, currAdmin, login, store))
res = -1;
if (downCount)
- if (!u->GetProperty().down.Set(down, *currAdmin, login, store))
+ 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);
+ 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->GetProperty().up.Set(usr->up.const_data(), currAdmin, login, store);
}*/
u->WriteConf();
if (strcasecmp(el, "DelUser") == 0)
{
if (!res)
- users->Del(u->GetLogin(), *currAdmin);
+ users->Del(u->GetLogin(), currAdmin);
return 0;
}