diff --git a/html/inc/token.inc b/html/inc/token.inc index 1dd52f1b84..807b9d9f86 100644 --- a/html/inc/token.inc +++ b/html/inc/token.inc @@ -16,10 +16,6 @@ // You should have received a copy of the GNU Lesser General Public License // along with BOINC. If not, see . -// express a time difference in readable form, e.g. "7 days ago". -// If it's more than 30 days, just show the date -// - require_once("../inc/boinc_db.inc"); require_once("../inc/util.inc"); @@ -38,8 +34,8 @@ function create_confirm_delete_account_token($user) { return $token; } -function is_valid_delete_account_token($user, $token) { - $boincToken = BoincToken::lookup_valid_token($user->id, $token, TOKEN_TYPE_DELETE_ACCOUNT); +function is_valid_delete_account_token($userid, $token) { + $boincToken = BoincToken::lookup_valid_token($userid, $token, TOKEN_TYPE_DELETE_ACCOUNT); if ( $boincToken == null ) { return false; } diff --git a/html/user/delete_account_confirm.php b/html/user/delete_account_confirm.php index e69de29bb2..85e19072d2 100644 --- a/html/user/delete_account_confirm.php +++ b/html/user/delete_account_confirm.php @@ -0,0 +1,55 @@ +. + +require_once("../inc/util.inc"); +require_once("../inc/account.inc"); +require_once("../inc/token.inc"); + +$config = get_config(); +if ( !parse_bool($config, "enable_delete_account") ) { + error_page( + tra("This feature is disabled. Please contact the project administrator.") + ); +} + +$userid = get_int("id"); +$token = get_str("token"); + +if( !is_valid_delete_account_token($userid, $token) ) { + sleep(LOGIN_FAIL_SLEEP_SEC); + error_page( + tra("The link you used has expired or is otherwise not valid. Please request a new one here") + ); +} + +page_head(tra("Delete Account")); + +echo "

".tra("Thank you for verifying ownership of your account.")."

" + ."

".tra("You can now delete your account by entering in your password below and clicking the \"Delete Account\" button.")."

" + ."

".tra("As a reminder, your account cannot be recovered once you delete it.")."

" + ."
"; + +form_start(secure_url_base()."delete_account_confirm_action.php", "post"); +form_input_hidden("token",$token); +form_input_hidden("id",$userid); +form_input_text(tra("Password"), "passwd", "", "password",'id="passwd"',passwd_visible_checkbox("passwd")); +form_submit(tra("Delete Account")); +form_end(); + +page_tail(); +?> \ No newline at end of file diff --git a/html/user/delete_account_confirm_action.php b/html/user/delete_account_confirm_action.php index e69de29bb2..4d01b0a677 100644 --- a/html/user/delete_account_confirm_action.php +++ b/html/user/delete_account_confirm_action.php @@ -0,0 +1,63 @@ +. + +require_once("../inc/util.inc"); +require_once("../inc/account.inc"); +require_once("../inc/token.inc"); +require_once("../inc/boinc_db.inc"); +require_once("../inc/user_util.inc"); + +//Make sure feature is enabled +$config = get_config(); +if ( !parse_bool($config, "enable_delete_account") ) { + error_page( + tra("This feature is disabled. Please contact the project administrator.") + ); +} + +//Make sure the token is still valid +$userid = post_int("id"); +$token = post_str("token"); +if( !is_valid_delete_account_token($userid, $token) ) { + sleep(LOGIN_FAIL_SLEEP_SEC); + error_page( + tra("The token you used has expired or is otherwise not valid. Please request a new one here") + ); +} + + +//Verify password +$user = $user = BoincUser::lookup_id($userid); +$passwd = post_str("passwd"); + +if( !check_passwd($user, $passwd) ) { + sleep(LOGIN_FAIL_SLEEP_SEC); + page_head("Password incorrect"); + echo "The password you entered is incorrect. Please go back and try again.\n"; + page_tail(); + exit; +} + +//do account delete + +page_head(tra("Account Deleted")); + +echo "

".tra("Your account has been deleted. If you want to contribute to ".PROJECT." in the future you will need to create a new account.")."

"; + +page_tail(); +?> \ No newline at end of file