mirror of
https://github.com/slawkens/myaac.git
synced 2025-10-24 06:15:02 +02:00

* Part 1 Removing closing tags when no HTML or other output comes after the last PHP codeblock. * Further removals * nothing --------- Co-authored-by: slawkens <slawkens@gmail.com>
169 lines
5.5 KiB
PHP
169 lines
5.5 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;
|
|
}
|
|
|
|
$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() + $config['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_mail.html.twig', array(
|
|
'new_email' => isset($_POST['new_email']) ? $_POST['new_email'] : null
|
|
));
|
|
}
|
|
}
|
|
else
|
|
{
|
|
$twig->display('account.change_mail.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"><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">
|
|
<input type="hidden" name="emailchangecancel" value=1 >
|
|
' . $twig->render('buttons.cancel.html.twig') . '
|
|
</form>
|
|
</td>
|
|
<td align=right>
|
|
<form action="?subtopic=accountmanagement" method="post" >
|
|
' . $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" >
|
|
<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" >
|
|
<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="?subtopic=accountmanagement" method="post" ><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
|
|
));
|
|
}
|