"); if (!$min_passwd_length) $min_passwd_length = 6; if (!is_ascii($passwd)) { error_page("Passwords may only include ASCII characters."); } if (strlen($passwd)<$min_passwd_length) { error_page( "New password is too short: minimum password length is $min_passwd_length characters." ); } if ($auth) { $user = lookup_user_auth($auth); if (!$user) { error_page("Invalid account key"); } } else { $user = lookup_user_email_addr($email_addr); if (!$user) { error_page("No account with that email address was found"); } $passwd_hash = md5($old_passwd.$email_addr); if ($user->passwd_hash != $passwd_hash) { error_page("Invalid password"); } } page_head("Change password"); $passwd_hash = md5($passwd.$user->email_addr); $result = $user->update("passwd_hash='$passwd_hash'"); if ($result) { echo "Your password has been changed."; } else { echo " We can't update your password due to a database problem. Please try again later. "; } page_tail(); ?>