mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-11 01:07:39 +08:00
102 lines
2.5 KiB
PHP
102 lines
2.5 KiB
PHP
<?php
|
|
|
|
namespace RainLoop\Providers;
|
|
|
|
class ChangePassword extends \RainLoop\Providers\AbstractProvider
|
|
{
|
|
/**
|
|
* @var \RainLoop\Actions
|
|
*/
|
|
private $oActions;
|
|
|
|
/**
|
|
* @var \RainLoop\Providers\ChangePassword\ChangePasswordInterface
|
|
*/
|
|
private $oDriver;
|
|
|
|
/**
|
|
* @var bool
|
|
*/
|
|
private $bCheckWeak;
|
|
|
|
/**
|
|
* @param \RainLoop\Actions $oActions
|
|
* @param \RainLoop\Providers\ChangePassword\ChangePasswordInterface|null $oDriver = null
|
|
* @param bool $bCheckWeak = true
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __construct($oActions, $oDriver = null, $bCheckWeak = true)
|
|
{
|
|
$this->oActions = $oActions;
|
|
$this->oDriver = $oDriver;
|
|
$this->bCheckWeak = !!$bCheckWeak;
|
|
}
|
|
|
|
/**
|
|
* @param \RainLoop\Account $oAccount
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function PasswordChangePossibility($oAccount)
|
|
{
|
|
return $this->IsActive() &&
|
|
$oAccount instanceof \RainLoop\Account &&
|
|
$this->oDriver && $this->oDriver->PasswordChangePossibility($oAccount)
|
|
;
|
|
}
|
|
|
|
/**
|
|
* @param \RainLoop\Account $oAccount
|
|
* @param string $sPrevPassword
|
|
* @param string $sNewPassword
|
|
*/
|
|
public function ChangePassword(\RainLoop\Account $oAccount, $sPrevPassword, $sNewPassword)
|
|
{
|
|
$mResult = false;
|
|
|
|
if ($this->oDriver instanceof \RainLoop\Providers\ChangePassword\ChangePasswordInterface &&
|
|
$this->PasswordChangePossibility($oAccount))
|
|
{
|
|
if ($sPrevPassword !== $oAccount->Password())
|
|
{
|
|
throw new \RainLoop\Exceptions\ClientException(\RainLoop\Notifications::CurrentPasswordIncorrect);
|
|
}
|
|
|
|
$sPasswordForCheck = \trim($sNewPassword);
|
|
if (6 > \strlen($sPasswordForCheck))
|
|
{
|
|
throw new \RainLoop\Exceptions\ClientException(\RainLoop\Notifications::NewPasswordShort);
|
|
}
|
|
|
|
if (!\MailSo\Base\Utils::PasswordWeaknessCheck($sPasswordForCheck))
|
|
{
|
|
throw new \RainLoop\Exceptions\ClientException(\RainLoop\Notifications::NewPasswordWeak);
|
|
}
|
|
|
|
if (!$this->oDriver->ChangePassword($oAccount, $sPrevPassword, $sNewPassword))
|
|
{
|
|
throw new \RainLoop\Exceptions\ClientException(\RainLoop\Notifications::CouldNotSaveNewPassword);
|
|
}
|
|
|
|
$oAccount->SetPassword($sNewPassword);
|
|
$this->oActions->SetAuthToken($oAccount);
|
|
|
|
$mResult = $this->oActions->GetSpecAuthToken();
|
|
}
|
|
else
|
|
{
|
|
throw new \RainLoop\Exceptions\ClientException(\RainLoop\Notifications::CouldNotSaveNewPassword);
|
|
}
|
|
|
|
return $mResult;
|
|
}
|
|
|
|
/**
|
|
* @return bool
|
|
*/
|
|
public function IsActive()
|
|
{
|
|
return $this->oDriver instanceof \RainLoop\Providers\ChangePassword\ChangePasswordInterface;
|
|
}
|
|
}
|