mirror of
				https://github.com/slawkens/myaac.git
				synced 2025-10-30 23:46:24 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			177 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			177 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * Change Email
 | |
|  *
 | |
|  * @package   MyAAC
 | |
|  * @author    Gesior <jerzyskalski@wp.pl>
 | |
|  * @author    Slawkens <slawkens@gmail.com>
 | |
|  * @copyright 2019 MyAAC
 | |
|  * @link      https://my-aac.org
 | |
|  */
 | |
| defined('MYAAC') or die('Direct access not allowed!');
 | |
| 
 | |
| $title = 'Change E-Mail';
 | |
| require __DIR__ . '/base.php';
 | |
| 
 | |
| if(!$logged) {
 | |
| 	return;
 | |
| }
 | |
| 
 | |
| csrfProtect();
 | |
| 
 | |
| $email_new_time = $account_logged->getCustomField("email_new_time");
 | |
| 
 | |
| if($email_new_time > 10) {
 | |
| 	$email_new = $account_logged->getCustomField("email_new");
 | |
| }
 | |
| 
 | |
| if($email_new_time < 10) {
 | |
| 	if(isset($_POST['changeemailsave']) && $_POST['changeemailsave'] == 1) {
 | |
| 		$email_new = $_POST['new_email'];
 | |
| 		$post_password = $_POST['password'];
 | |
| 
 | |
| 		if(!Validator::email($email_new)) {
 | |
| 			$errors[] = Validator::getLastError();
 | |
| 		}
 | |
| 
 | |
| 		if(empty($post_password)) {
 | |
| 			$errors[] = 'Please enter password to your account.';
 | |
| 		}
 | |
| 		else {
 | |
| 			$post_password = encrypt((USE_ACCOUNT_SALT ? $account_logged->getCustomField('salt') : '') . $post_password);
 | |
| 			if($post_password != $account_logged->getPassword()) {
 | |
| 				$errors[] = 'Wrong password to account.';
 | |
| 			}
 | |
| 		}
 | |
| 
 | |
| 		if(empty($errors)) {
 | |
| 			$email_new_time = time() + setting('core.account_mail_change') * 24 * 3600;
 | |
| 			$account_logged->setCustomField("email_new", $email_new);
 | |
| 			$account_logged->setCustomField("email_new_time", $email_new_time);
 | |
| 			$twig->display('success.html.twig', array(
 | |
| 				'title' => 'New Email Address Requested',
 | |
| 				'description' => 'You have requested to change your email address to <b>' . $email_new . '</b>. The actual change will take place after <b>' . date("j F Y, G:i:s", $email_new_time) . '</b>, during which you can cancel the request at any time.'
 | |
| 			));
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			//show errors
 | |
| 			$twig->display('error_box.html.twig', array('errors' => $errors));
 | |
| 
 | |
| 			//show form
 | |
| 			$twig->display('account.change-email.html.twig', array(
 | |
| 				'new_email' => isset($_POST['new_email']) ? $_POST['new_email'] : null
 | |
| 			));
 | |
| 		}
 | |
| 	}
 | |
| 	else
 | |
| 	{
 | |
| 		$twig->display('account.change-email.html.twig', array(
 | |
| 			'new_email' => isset($_POST['new_email']) ? $_POST['new_email'] : null
 | |
| 		));
 | |
| 	}
 | |
| 
 | |
| }
 | |
| else
 | |
| {
 | |
| 	if($email_new_time < time()) {
 | |
| 		if (isset($_POST['changeemailsave']) && $_POST['changeemailsave'] == 1) {
 | |
| 			$account_logged->setCustomField("email_new", "");
 | |
| 			$account_logged->setCustomField("email_new_time", 0);
 | |
| 			$account_logged->setEmail($email_new);
 | |
| 			$account_logged->save();
 | |
| 			$account_logged->logAction('Account email changed to <b>' . $email_new . '</b>');
 | |
| 
 | |
| 			$twig->display('success.html.twig', array(
 | |
| 				'title' => 'Email Address Change Accepted',
 | |
| 				'description' => 'You have accepted <b>' . $account_logged->getEmail() . '</b> as your new email adress.'
 | |
| 			));
 | |
| 		}
 | |
| 		else
 | |
| 		{
 | |
| 			$custom_buttons = '
 | |
| <table width="100%">
 | |
| 	<tr>
 | |
| 		<td width="30"> </td>
 | |
| 		<td align=left>
 | |
| 			<form action="' . getLink('account/email') . '" method="post">
 | |
| 				' . csrf(true) . '
 | |
| 				<input type="hidden" name="changeemailsave" value=1 >
 | |
| 				<INPUT TYPE=image NAME="I Agree" SRC="' . $template_path . '/images/global/buttons/sbutton_iagree.gif" BORDER=0 WIDTH=120 HEIGHT=17>
 | |
| 			</form>
 | |
| 		</td>
 | |
| 		<td align=left>
 | |
| 			<form action="' . getLink('account/email') . '" method="post">
 | |
| 				' . csrf(true) . '
 | |
| 				<input type="hidden" name="emailchangecancel" value=1 >
 | |
| 				' . $twig->render('buttons.cancel.html.twig') . '
 | |
| 			</form>
 | |
| 		</td>
 | |
| 		<td align=right>
 | |
| 			<form action="' . getLink('account/manage') . '" method="post" >
 | |
| 				' . csrf(true) . '
 | |
| 				' . $twig->render('buttons.back.html.twig') . '
 | |
| 			</form>
 | |
| 		</td>
 | |
| 		<td width="30"> </td>
 | |
| 	</tr>
 | |
| </table>';
 | |
| 			$twig->display('success.html.twig', array(
 | |
| 				'title' => 'Email Address Change Accepted',
 | |
| 				'description' => 'Do you accept <b>'.$email_new.'</b> as your new email adress?',
 | |
| 				'custom_buttons' => $custom_buttons
 | |
| 			));
 | |
| 		}
 | |
| 	}
 | |
| 	else if(!isset($_POST['emailchangecancel']) || $_POST['emailchangecancel'] != 1)
 | |
| 	{
 | |
| 		$custom_buttons = '
 | |
| <table style="width:100%;" >
 | |
| 	<tr align="center">
 | |
| 		<td>
 | |
| 			<table border="0" cellspacing="0" cellpadding="0" >
 | |
| 				<form action="' .getLink('account/email') . '" method="post" >
 | |
| 					' . csrf(true) . '
 | |
| 					<tr>
 | |
| 						<td style="border:0px;" >
 | |
| 							<input type="hidden" name="emailchangecancel" value="1" >
 | |
| 							' . $twig->render('buttons.cancel.html.twig') . '
 | |
| 						</td>
 | |
| 					</tr>
 | |
| 				</form>
 | |
| 			</table>
 | |
| 		</td>
 | |
| 		<td>
 | |
| 			<table border="0" cellspacing="0" cellpadding="0" >
 | |
| 				<form action="' . getLink('account/manage') . '" method="post" >
 | |
| 					' . csrf(true) . '
 | |
| 					<tr>
 | |
| 						<td style="border:0px;" >
 | |
| 							' . $twig->render('buttons.back.html.twig') . '
 | |
| 						</td>
 | |
| 					</tr>
 | |
| 				</form>
 | |
| 			</table>
 | |
| 		</td>
 | |
| 	</tr>
 | |
| </table>';
 | |
| 		$twig->display('success.html.twig', array(
 | |
| 			'title' => 'Change of Email Address',
 | |
| 			'description' => 'A request has been submitted to change the email address of this account to <b>'.$email_new.'</b>.<br/>The actual change will take place on <b>'.date("j F Y, G:i:s", $email_new_time).'</b>.<br>If you do not want to change your email address, please click on "Cancel".',
 | |
| 			'custom_buttons' => $custom_buttons
 | |
| 		));
 | |
| 	}
 | |
| }
 | |
| if(isset($_POST['emailchangecancel']) && $_POST['emailchangecancel'] == 1) {
 | |
| 	$account_logged->setCustomField("email_new", "");
 | |
| 	$account_logged->setCustomField("email_new_time", 0);
 | |
| 
 | |
| 	$custom_buttons = '<div style="text-align:center"><table border="0" cellspacing="0" cellpadding="0" ><form action="' . getLink('account/manage') . '" method="post" >' . csrf(true) . '<tr><td style="border:0px;" >' . $twig->render('buttons.back.html.twig') . '</td></tr></form></table></div>';
 | |
| 
 | |
| 	$twig->display('success.html.twig', array(
 | |
| 		'title' => 'Email Address Change Cancelled',
 | |
| 		'description' => 'Your request to change the email address of your account has been cancelled. The email address will not be changed.',
 | |
| 		'custom_buttons' => $custom_buttons
 | |
| 	));
 | |
| }
 | 
