mirror of
https://github.com/slawkens/myaac.git
synced 2025-04-27 01:39:22 +02:00
83 lines
2.5 KiB
PHP
83 lines
2.5 KiB
PHP
<?php
|
|
/**
|
|
* Change password
|
|
*
|
|
* @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!');
|
|
|
|
$new_password = isset($_POST['newpassword']) ? $_POST['newpassword'] : NULL;
|
|
$new_password2 = isset($_POST['newpassword2']) ? $_POST['newpassword2'] : NULL;
|
|
$old_password = isset($_POST['oldpassword']) ? $_POST['oldpassword'] : NULL;
|
|
if(empty($new_password) && empty($new_password2) && empty($old_password)) {
|
|
$twig->display('account.change_password.html.twig');
|
|
}
|
|
else
|
|
{
|
|
if(empty($new_password) || empty($new_password2) || empty($old_password)){
|
|
$errors[] = "Please fill in form.";
|
|
}
|
|
$password_strlen = strlen($new_password);
|
|
if($new_password != $new_password2) {
|
|
$errors[] = "The new passwords do not match!";
|
|
}
|
|
|
|
if(empty($errors)) {
|
|
if(!Validator::password($new_password)) {
|
|
$errors[] = Validator::getLastError();
|
|
}
|
|
|
|
$old_password = encrypt(($config_salt_enabled ? $account_logged->getCustomField('salt') : '') . $old_password);
|
|
if($old_password != $account_logged->getPassword()) {
|
|
$errors[] = "Current password is incorrect!";
|
|
}
|
|
}
|
|
if(!empty($errors)){
|
|
//show errors
|
|
$twig->display('error_box.html.twig', array('errors' => $errors));
|
|
|
|
//show form
|
|
$twig->display('account.change_password.html.twig');
|
|
}
|
|
else
|
|
{
|
|
$org_pass = $new_password;
|
|
|
|
if($config_salt_enabled)
|
|
{
|
|
$salt = generateRandomString(10, false, true, true);
|
|
$new_password = $salt . $new_password;
|
|
$account_logged->setCustomField('salt', $salt);
|
|
}
|
|
|
|
$new_password = encrypt($new_password);
|
|
$account_logged->setPassword($new_password);
|
|
$account_logged->save();
|
|
$account_logged->logAction('Account password changed.');
|
|
|
|
$message = '';
|
|
if($config['mail_enabled'] && $config['send_mail_when_change_password'])
|
|
{
|
|
$mailBody = $twig->render('mail.password_changed.html.twig', array(
|
|
'new_password' => $org_pass
|
|
));
|
|
|
|
if(_mail($account_logged->getEMail(), $config['lua']['serverName']." - Changed password", $mailBody))
|
|
$message = '<br/><small>Your new password were send on email address <b>'.$account_logged->getEMail().'</b>.</small>';
|
|
else
|
|
$message = '<br/><p class="error">An error occurred while sending email. For Admin: More info can be found in system/logs/mailer-error.log</p>';
|
|
}
|
|
|
|
$twig->display('success.html.twig', array(
|
|
'title' => 'Password Changed',
|
|
'description' => 'Your password has been changed.' . $message
|
|
));
|
|
setSession('password', $new_password);
|
|
}
|
|
}
|
|
|
|
?>
|