2005-08-09 18:46:53 +00:00
|
|
|
<?php
|
2008-08-05 22:43:14 +00:00
|
|
|
// This file is part of BOINC.
|
|
|
|
// http://boinc.berkeley.edu
|
|
|
|
// Copyright (C) 2008 University of California
|
|
|
|
//
|
|
|
|
// BOINC is free software; you can redistribute it and/or modify it
|
|
|
|
// under the terms of the GNU Lesser General Public License
|
|
|
|
// as published by the Free Software Foundation,
|
|
|
|
// either version 3 of the License, or (at your option) any later version.
|
|
|
|
//
|
|
|
|
// BOINC 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 Lesser General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Lesser General Public License
|
|
|
|
// along with BOINC. If not, see <http://www.gnu.org/licenses/>.
|
2005-08-09 18:46:53 +00:00
|
|
|
|
|
|
|
// RPC handler for account lookup
|
|
|
|
|
2007-11-12 22:28:17 +00:00
|
|
|
require_once("../inc/boinc_db.inc");
|
2005-08-09 18:46:53 +00:00
|
|
|
require_once("../inc/util.inc");
|
|
|
|
require_once("../inc/email.inc");
|
|
|
|
require_once("../inc/xml.inc");
|
2014-10-19 06:53:27 +00:00
|
|
|
require_once("../inc/ldap.inc");
|
2018-04-04 18:47:26 +00:00
|
|
|
require_once("../inc/user_util.inc");
|
|
|
|
require_once("../inc/password_compat/password.inc");
|
2005-08-09 18:46:53 +00:00
|
|
|
|
|
|
|
xml_header();
|
2006-09-06 20:56:55 +00:00
|
|
|
$retval = db_init_xml();
|
|
|
|
if ($retval) xml_error($retval);
|
2005-08-09 18:46:53 +00:00
|
|
|
|
2014-10-19 06:53:27 +00:00
|
|
|
$ldap_auth = get_str("ldap_auth", true);
|
2005-08-09 18:46:53 +00:00
|
|
|
|
2014-10-19 06:53:27 +00:00
|
|
|
if (LDAP_HOST && $ldap_auth) {
|
|
|
|
// LDAP case.
|
|
|
|
//
|
|
|
|
$ldap_uid = get_str("ldap_uid");
|
|
|
|
$passwd = get_str("passwd");
|
|
|
|
list ($ldap_user, $error_msg) = ldap_auth($ldap_uid, $passwd);
|
|
|
|
if ($error_msg) {
|
2017-01-12 21:19:01 +00:00
|
|
|
sleep(LOGIN_FAIL_SLEEP_SEC);
|
2014-10-19 06:53:27 +00:00
|
|
|
xml_error(ERR_BAD_USER_NAME, $error_msg);
|
|
|
|
}
|
|
|
|
$x = ldap_email_string($ldap_uid);
|
|
|
|
$user = BoincUser::lookup_email_addr($x);
|
|
|
|
if (!$user) {
|
|
|
|
$user = make_user_ldap($x, $ldap_user->name);
|
|
|
|
if (!$user) {
|
|
|
|
xml_error(-1, "user record creation failed");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// normal (non-LDAP) case
|
|
|
|
$email_addr = get_str("email_addr");
|
|
|
|
$passwd_hash = get_str("passwd_hash", true);
|
2005-11-26 20:56:54 +00:00
|
|
|
|
2014-10-19 06:53:27 +00:00
|
|
|
$email_addr = BoincDb::escape_string($email_addr);
|
|
|
|
$user = BoincUser::lookup("email_addr='$email_addr'");
|
|
|
|
if (!$user) {
|
2017-01-12 21:19:01 +00:00
|
|
|
sleep(LOGIN_FAIL_SLEEP_SEC);
|
2014-10-19 06:53:27 +00:00
|
|
|
xml_error(ERR_DB_NOT_FOUND);
|
|
|
|
}
|
2006-06-16 21:19:00 +00:00
|
|
|
|
2014-10-19 06:53:27 +00:00
|
|
|
if (!$passwd_hash) {
|
|
|
|
echo "<account_out>\n";
|
|
|
|
echo " <success/>\n";
|
|
|
|
echo "</account_out>\n";
|
|
|
|
exit();
|
|
|
|
}
|
2005-11-19 20:33:55 +00:00
|
|
|
|
2014-10-19 06:53:27 +00:00
|
|
|
$auth_hash = md5($user->authenticator.$user->email_addr);
|
2005-11-19 20:33:55 +00:00
|
|
|
|
2014-10-19 06:53:27 +00:00
|
|
|
// if no password set, set password to account key
|
|
|
|
//
|
|
|
|
if (!strlen($user->passwd_hash)) {
|
2018-03-13 21:49:14 +00:00
|
|
|
$user->passwd_hash = password_hash($auth_hash, PASSWORD_DEFAULT);
|
|
|
|
$user->update(" passwd_hash='$user->passwd_hash' ");
|
2014-10-19 06:53:27 +00:00
|
|
|
}
|
2018-03-09 21:05:16 +00:00
|
|
|
|
2018-03-13 21:49:14 +00:00
|
|
|
if (password_verify($passwd_hash, $user->passwd_hash)) {
|
2018-03-09 21:05:16 +00:00
|
|
|
// on valid login, rehash password if necessary to upgrade hash overtime
|
|
|
|
// as the defaults change.
|
2018-03-13 21:49:14 +00:00
|
|
|
if (password_needs_rehash($user->passwd_hash, PASSWORD_DEFAULT)) {
|
|
|
|
do_passwd_rehash($user, $passwd_hash);
|
2018-03-09 21:05:16 +00:00
|
|
|
}
|
2018-03-13 21:49:14 +00:00
|
|
|
} else if ($passwd_hash == $user->passwd_hash) {
|
2018-03-09 21:05:16 +00:00
|
|
|
// if password is the legacy md5 hash, then rehash to update to
|
|
|
|
// a more secure hash
|
2018-03-13 21:49:14 +00:00
|
|
|
do_passwd_rehash($user, $passwd_hash);
|
|
|
|
} else if ($auth_hash == $passwd_hash) {
|
2018-03-09 21:05:16 +00:00
|
|
|
// if the passed hash matches the auth hash, then allow it
|
|
|
|
} else {
|
|
|
|
// if none of the above match, the password is invalid
|
2017-01-12 21:19:01 +00:00
|
|
|
sleep(LOGIN_FAIL_SLEEP_SEC);
|
2014-10-19 06:53:27 +00:00
|
|
|
xml_error(ERR_BAD_PASSWD);
|
|
|
|
}
|
2018-03-09 21:05:16 +00:00
|
|
|
|
2014-10-19 06:53:27 +00:00
|
|
|
}
|
2014-10-19 16:32:59 +00:00
|
|
|
echo "<account_out>\n";
|
|
|
|
echo "<authenticator>$user->authenticator</authenticator>\n";
|
|
|
|
echo "</account_out>\n";
|
2005-08-09 18:46:53 +00:00
|
|
|
?>
|