urbackup_backend/urbackupserver/serverinterface/salt.cpp
Martin 282f2c96ad Log attempts where username does not exist as failed login attempts
(cherry picked from commit c01c1d6074fccc44887b3cf5abfcdb203969748c)
(cherry picked from commit f977848aa6)
2018-06-01 10:44:42 +02:00

77 lines
2.2 KiB
C++

/*************************************************************************
* UrBackup - Client/Server backup system
* Copyright (C) 2011-2016 Martin Raiber
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
**************************************************************************/
#ifndef CLIENT_ONLY
#include "action_header.h"
#include "../server_settings.h"
#include "login.h"
ACTION_IMPL(salt)
{
Helper helper(tid, &POST, &PARAMS);
JSON::Object ret;
std::string username=POST["username"];
if(helper.getSession()==NULL && !username.empty())
{
std::string ses=helper.generateSession(username);
ret.set("ses", JSON::Value(ses));
POST["ses"]=ses;
helper.update(tid, &POST, &PARAMS);
}
SUser *session=helper.getSession();
if(session!=NULL)
{
if(username.empty())
{
str_map::iterator iter=session->mStr.find("username");
if(iter!=session->mStr.end())
{
username=iter->second;
}
}
IQuery *q=helper.getDatabase()->Prepare("SELECT salt, pbkdf2_rounds FROM settings_db.si_users WHERE name=?");
q->Bind(username);
db_results res=q->Read();
if(res.empty())
{
logFailedLogin(helper, PARAMS, username, LoginMethod_Webinterface);
ret.set("error", JSON::Value(0));
}
else
{
ret.set("salt", res[0]["salt"]);
ret.set("pbkdf2_rounds", watoi(res[0]["pbkdf2_rounds"]));
std::string rnd=ServerSettings::generateRandomAuthKey();
ret.set("rnd", JSON::Value(rnd));
session->mStr["rnd"]=rnd;
}
}
else
{
ret.set("error", JSON::Value(1));
}
helper.Write(ret.stringify(false));
}
#endif //CLIENT_ONLY