2002-11-11 19:40:22 +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/>.
|
2002-11-11 19:40:22 +00:00
|
|
|
|
2007-11-12 22:28:17 +00:00
|
|
|
include_once("../inc/boinc_db.inc");
|
2004-02-02 23:34:39 +00:00
|
|
|
include_once("../inc/util.inc");
|
2004-11-18 20:01:12 +00:00
|
|
|
include_once("../inc/email.inc");
|
2007-07-25 15:11:14 +00:00
|
|
|
include_once("../inc/user.inc");
|
2011-06-20 17:17:56 +00:00
|
|
|
include_once("../inc/recaptchalib.php");
|
2002-11-11 19:40:22 +00:00
|
|
|
|
|
|
|
function show_error($str) {
|
2011-08-25 22:12:48 +00:00
|
|
|
page_head(tra("Can't create account"));
|
2003-02-19 20:34:33 +00:00
|
|
|
echo "$str<br>\n";
|
2007-11-12 22:28:17 +00:00
|
|
|
echo BoincDb::error();
|
2011-08-25 22:12:48 +00:00
|
|
|
echo "<p>".tra("Click your browser's <b>Back</b> button to try again.")."\n</p>\n";
|
2002-11-11 19:40:22 +00:00
|
|
|
page_tail();
|
|
|
|
exit();
|
|
|
|
}
|
|
|
|
|
2005-02-13 20:57:43 +00:00
|
|
|
$config = get_config();
|
2011-09-13 04:53:13 +00:00
|
|
|
if (parse_bool($config, "disable_account_creation")
|
|
|
|
|| parse_bool($config, "no_web_account_creation")
|
|
|
|
) {
|
2011-08-25 22:12:48 +00:00
|
|
|
page_head(tra("Account creation is disabled"));
|
2005-02-13 20:57:43 +00:00
|
|
|
echo "
|
2011-08-25 22:12:48 +00:00
|
|
|
<h3>".tra("Account creation is disabled")."</h3>
|
|
|
|
".tra("Sorry, this project has disabled the creation of new accounts.
|
|
|
|
Please try again later.")."
|
2005-02-13 20:57:43 +00:00
|
|
|
";
|
|
|
|
exit();
|
|
|
|
}
|
2003-03-26 00:48:56 +00:00
|
|
|
|
2011-06-20 17:17:56 +00:00
|
|
|
$privatekey = parse_config($config, "<recaptcha_private_key>");
|
|
|
|
if ($privatekey) {
|
|
|
|
$resp = recaptcha_check_answer($privatekey, $_SERVER["REMOTE_ADDR"],
|
|
|
|
$_POST["recaptcha_challenge_field"], $_POST["recaptcha_response_field"]
|
|
|
|
);
|
|
|
|
if (!$resp->is_valid) {
|
2011-08-25 22:12:48 +00:00
|
|
|
echo tra("Your reCAPTCHA response was not correct. Please try again.");
|
2011-06-20 17:17:56 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-11-07 17:23:29 +00:00
|
|
|
// see whether the new account should be pre-enrolled in a team,
|
|
|
|
// and initialized with its founder's project prefs
|
|
|
|
//
|
2005-02-14 18:33:08 +00:00
|
|
|
$teamid = post_int("teamid", true);
|
2005-02-13 20:57:43 +00:00
|
|
|
if ($teamid) {
|
|
|
|
$team = lookup_team($teamid);
|
|
|
|
$clone_user = lookup_user_id($team->userid);
|
|
|
|
if (!$clone_user) {
|
2011-08-25 22:12:48 +00:00
|
|
|
error_page("User $userid not found");
|
2003-07-04 00:02:53 +00:00
|
|
|
}
|
2005-02-13 20:57:43 +00:00
|
|
|
$project_prefs = $clone_user->project_prefs;
|
|
|
|
} else {
|
|
|
|
$teamid = 0;
|
|
|
|
$project_prefs = "";
|
|
|
|
}
|
2003-07-04 00:02:53 +00:00
|
|
|
|
2006-05-27 21:41:36 +00:00
|
|
|
if(defined('INVITE_CODES')) {
|
2008-06-11 19:36:10 +00:00
|
|
|
$invite_code = post_str("invite_code");
|
2006-05-27 21:41:36 +00:00
|
|
|
if (strlen($invite_code)==0) {
|
2007-11-02 14:43:02 +00:00
|
|
|
show_error(tra("You must supply an invitation code to create an account."));
|
2006-05-27 21:41:36 +00:00
|
|
|
}
|
|
|
|
if (!preg_match(INVITE_CODES, $invite_code)) {
|
2007-11-02 14:43:02 +00:00
|
|
|
show_error(tra("The invitation code you gave is not valid."));
|
2006-05-27 21:41:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-06-11 19:36:10 +00:00
|
|
|
$new_name = post_str("new_name");
|
2012-03-24 06:31:03 +00:00
|
|
|
if (!is_valid_user_name($new_name, $reason)) {
|
|
|
|
show_error($reason);
|
2005-02-22 19:37:55 +00:00
|
|
|
}
|
|
|
|
|
2011-08-25 22:12:48 +00:00
|
|
|
$new_email_addr = strtolower(post_str("new_email_addr"));
|
2005-02-13 20:57:43 +00:00
|
|
|
if (!is_valid_email_addr($new_email_addr)) {
|
2011-08-25 22:12:48 +00:00
|
|
|
show_error(tra("Invalid email address: you must enter a valid address of the form name@domain"));
|
2005-02-13 20:57:43 +00:00
|
|
|
}
|
2005-03-24 19:02:27 +00:00
|
|
|
$user = lookup_user_email_addr($new_email_addr);
|
|
|
|
if ($user) {
|
2011-08-25 22:12:48 +00:00
|
|
|
show_error(tra("There's already an account with that email address."));
|
2005-02-13 20:57:43 +00:00
|
|
|
}
|
2002-11-11 19:40:22 +00:00
|
|
|
|
2008-06-11 19:36:10 +00:00
|
|
|
$passwd = post_str("passwd");
|
|
|
|
$passwd2 = post_str("passwd2");
|
2005-10-12 22:51:55 +00:00
|
|
|
if ($passwd != $passwd2) {
|
2011-08-25 22:12:48 +00:00
|
|
|
show_error(tra("New passwords are different"));
|
2005-10-12 22:51:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
$min_passwd_length = parse_config($config, "<min_passwd_length>");
|
|
|
|
if (!$min_passwd_length) $min_passwd_length = 6;
|
|
|
|
|
|
|
|
if (!is_ascii($passwd)) {
|
2011-08-25 22:12:48 +00:00
|
|
|
show_error(tra("Passwords may only include ASCII characters."));
|
2005-10-12 22:51:55 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (strlen($passwd)<$min_passwd_length) {
|
|
|
|
show_error(
|
2011-08-25 22:12:48 +00:00
|
|
|
tra("New password is too short: minimum password length is %1 characters.", $min_passwd_length)
|
2005-10-12 22:51:55 +00:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
$passwd_hash = md5($passwd.$new_email_addr);
|
|
|
|
|
2007-08-26 10:29:08 +00:00
|
|
|
$country = post_str("country");
|
|
|
|
if ($country == "") {
|
|
|
|
$country = "International";
|
|
|
|
}
|
2005-02-13 20:57:43 +00:00
|
|
|
if (!is_valid_country($country)) {
|
2011-08-25 22:12:48 +00:00
|
|
|
error_page("bad country");
|
2005-02-13 20:57:43 +00:00
|
|
|
}
|
2004-12-27 03:42:11 +00:00
|
|
|
|
2011-08-25 22:12:48 +00:00
|
|
|
$postal_code = sanitize_tags(post_str("postal_code", true));
|
2004-12-27 03:42:11 +00:00
|
|
|
|
2007-07-25 15:11:14 +00:00
|
|
|
$user = make_user(
|
|
|
|
$new_email_addr, $new_name, $passwd_hash,
|
|
|
|
$country, $postal_code, $project_prefs, $teamid
|
|
|
|
);
|
|
|
|
if (!$user) {
|
2011-08-25 22:12:48 +00:00
|
|
|
show_error(tra("Couldn't create account"));
|
2005-02-13 20:57:43 +00:00
|
|
|
}
|
|
|
|
|
2006-11-15 20:15:01 +00:00
|
|
|
if(defined('INVITE_CODES')) {
|
2007-07-25 15:11:14 +00:00
|
|
|
error_log("Account '$new_email_addr' created using invitation code '$invite_code'");
|
2006-11-15 20:15:01 +00:00
|
|
|
}
|
|
|
|
|
2008-09-25 22:03:56 +00:00
|
|
|
// In success case, redirect to a fixed page so that user can
|
|
|
|
// return to it without getting "Repost form data" stuff
|
|
|
|
|
2008-02-13 19:54:54 +00:00
|
|
|
$next_url = post_str('next_url', true);
|
2010-09-04 22:13:27 +00:00
|
|
|
$next_url = sanitize_local_url($next_url);
|
2008-02-13 19:54:54 +00:00
|
|
|
if ($next_url) {
|
2010-08-29 10:24:39 +00:00
|
|
|
Header("Location: ".URL_BASE."$next_url");
|
2008-02-13 19:54:54 +00:00
|
|
|
} else {
|
2010-08-29 10:24:39 +00:00
|
|
|
Header("Location: ".URL_BASE."home.php");
|
2008-02-13 19:54:54 +00:00
|
|
|
send_cookie('init', "1", true);
|
|
|
|
send_cookie('via_web', "1", true);
|
|
|
|
}
|
2008-02-13 19:02:44 +00:00
|
|
|
send_cookie('auth', $user->authenticator, true);
|
2002-12-06 21:37:30 +00:00
|
|
|
|
2005-02-13 20:57:43 +00:00
|
|
|
?>
|