. require_once("../inc/boinc_db.inc"); require_once("../inc/util.inc"); require_once("../inc/user.inc"); check_get_args(array()); $auth = post_str("auth", true); $email_addr = strtolower(post_str("email_addr", true)); $old_passwd = post_str("old_passwd", true); $passwd = post_str("passwd"); $passwd2 = post_str("passwd2"); if ($passwd != $passwd2) { error_page(tra("New passwords are different")); } $config = get_config(); $min_passwd_length = parse_config($config, ""); if (!$min_passwd_length) $min_passwd_length = 6; if (!is_ascii($passwd)) { error_page(tra("Passwords may only include ASCII characters.")); } if (strlen($passwd)<$min_passwd_length) { error_page(tra("New password is too short: minimum password length is %1 characters.", $min_passwd_length)); } if ($auth) { $user = BoincUser::lookup_auth($auth); if (!$user) { error_page(tra("Invalid account key")); } } else { $user = BoincUser::lookup_email_addr($email_addr); if (!$user) { error_page(tra("No account with that email address was found")); } $passwd_hash = md5($old_passwd.$email_addr); if ($user->passwd_hash != $passwd_hash) { error_page(tra("Invalid password")); } } page_head(tra("Change password")); $passwd_hash = md5($passwd.$user->email_addr); $result = $user->update("passwd_hash='$passwd_hash'"); if ($result) { echo tra("Your password has been changed."); } else { echo tra("We can't update your password due to a database problem. Please try again later."); } page_tail(); ?>