X-Git-Url: https://git.stg.codes/stg.git/blobdiff_plain/1347f3d1e04bedd1508589173f577673ee2c5554..0093be0eb4dbe201a7d63da1de47f98c68987b1d:/projects/stargazer/plugins/configuration/sgconfig/parser.cpp
diff --git a/projects/stargazer/plugins/configuration/sgconfig/parser.cpp b/projects/stargazer/plugins/configuration/sgconfig/parser.cpp
index 1f7757d2..7deab3d0 100644
--- a/projects/stargazer/plugins/configuration/sgconfig/parser.cpp
+++ b/projects/stargazer/plugins/configuration/sgconfig/parser.cpp
@@ -133,8 +133,7 @@ answerList->erase(answerList->begin(), answerList->end());
if (users->FindByName(login, &u))
{
- s = "";
- answerList->push_back(s);
+ answerList->push_back("");
return;
}
@@ -286,6 +285,13 @@ answerList->push_back(s);
strprintf(&s, "", u->GetProperty().creditExpire.Get());
answerList->push_back(s);
+s = "";
+std::vector list(u->GetAuthorizers());
+for (std::vector::const_iterator it = list.begin(); it != list.end(); ++it)
+ s += "";
+s += "";
+answerList->push_back(s);
+
strprintf(&s, "");
answerList->push_back(s);
}
@@ -1025,9 +1031,23 @@ 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());
+ res = -1;
return -1;
}
+for (size_t i = 0; i < ucr->ips.const_data().Count(); ++i)
+ {
+ CONST_USER_PTR user;
+ uint32_t ip = ucr->ips.const_data().operator[](i).ip;
+ if (users->IsIPInUse(ip, login, &user))
+ {
+ printfd(__FILE__, "Trying to assign an IP %s to '%s' that is already in use by '%s'\n", inet_ntostring(ip).c_str(), login.c_str(), user->GetLogin().c_str());
+ GetStgLogger()("%s trying to assign an IP %s to '%s' that is currently in use by '%s'", currAdmin->GetLogStr().c_str(), inet_ntostring(ip).c_str(), login.c_str(), user->GetLogin().c_str());
+ res = -1;
+ return -1;
+ }
+ }
+
if (!ucr->ips.res_empty())
if (!u->GetProperty().ips.Set(ucr->ips.const_data(), currAdmin, login, store))
res = -1;
@@ -1342,11 +1362,11 @@ switch (result)
break;
case res_params_error:
printfd(__FILE__, "res_params_error\n");
- answerList->push_back("");
+ answerList->push_back("");
break;
case res_unknown:
printfd(__FILE__, "res_unknown\n");
- answerList->push_back("");
+ answerList->push_back("");
break;
default:
printfd(__FILE__, "res_default\n");
@@ -1400,30 +1420,17 @@ else
answerList->push_back("");
}
//-----------------------------------------------------------------------------
-/*void PARSERDELUSER::CreateAnswer(char * mes)
-{
-//answerList->clear();
-answerList->erase(answerList->begin(), answerList->end());
-
-char str[255];
-sprintf(str, "", mes);
-answerList->push_back(str);
-}*/
-//-----------------------------------------------------------------------------
// CHECK USER
//
//-----------------------------------------------------------------------------
int PARSER_CHECK_USER::ParseStart(void *, const char *el, const char **attr)
{
-result = false;
-
if (strcasecmp(el, "CheckUser") == 0)
{
if (attr[0] == NULL || attr[1] == NULL
|| attr[2] == NULL || attr[3] == NULL)
{
- result = false;
- CreateAnswer();
+ CreateAnswer("Invalid parameters.");
printfd(__FILE__, "PARSER_CHECK_USER - attr err\n");
return 0;
}
@@ -1431,22 +1438,19 @@ if (strcasecmp(el, "CheckUser") == 0)
USER_PTR user;
if (users->FindByName(attr[1], &user))
{
- result = false;
- CreateAnswer();
+ CreateAnswer("User not found.");
printfd(__FILE__, "PARSER_CHECK_USER - login err\n");
return 0;
}
if (strcmp(user->GetProperty().password.Get().c_str(), attr[3]))
{
- result = false;
- CreateAnswer();
+ CreateAnswer("Wrong password.");
printfd(__FILE__, "PARSER_CHECK_USER - passwd err\n");
return 0;
}
- result = true;
- CreateAnswer();
+ CreateAnswer(NULL);
return 0;
}
return -1;
@@ -1461,12 +1465,12 @@ if (strcasecmp(el, "CheckUser") == 0)
return -1;
}
//-----------------------------------------------------------------------------
-void PARSER_CHECK_USER::CreateAnswer()
+void PARSER_CHECK_USER::CreateAnswer(const char * error)
{
-if (result)
- answerList->push_back("");
+if (error)
+ answerList->push_back(std::string("");
else
- answerList->push_back("");
+ answerList->push_back("");
}
//-----------------------------------------------------------------------------
//-----------------------------------------------------------------------------