mHost = $mHost; return $this; } /** * @param string $mUser * * @return \ChangePasswordCustomSqlDriver */ public function SetmUser($mUser) { $this->mUser = $mUser; return $this; } /** * @param string $mPass * * @return \ChangePasswordCustomSqlDriver */ public function SetmPass($mPass) { $this->mPass = $mPass; return $this; } /** * @param string $mDatabase * * @return \ChangePasswordCustomSqlDriver */ public function SetmDatabase($mDatabase) { $this->mDatabase = $mDatabase; return $this; } /** * @param string $mTable * * @return \ChangePasswordCustomSqlDriver */ public function SetmTable($mTable) { $this->mTable = $mTable; return $this; } /** * @param string $mSql * * @return \ChangePasswordCustomSqlDriver */ public function SetmSql($mSql) { $this->mSql = $mSql; return $this; } /** * @param \MailSo\Log\Logger $oLogger * * @return \ChangePasswordCustomSqlDriver */ public function SetLogger($oLogger) { if ($oLogger instanceof \MailSo\Log\Logger) { $this->oLogger = $oLogger; } return $this; } /** * @param \RainLoop\Account $oAccount * * @return bool */ public function PasswordChangePossibility($oAccount) { return $oAccount && $oAccount->Email(); } /** * @param \RainLoop\Account $oAccount * @param string $sPrevPassword * @param string $sNewPassword * * @return bool */ public function ChangePassword(\RainLoop\Account $oAccount, $sPrevPassword, $sNewPassword) { if ($this->oLogger) { $this->oLogger->Write('Try to change password for '.$oAccount->Email()); } $bResult = false; $dsn = 'mysql:host='.$this->mHost.';dbname='.$this->mDatabase.';charset=utf8'; $options = array( PDO::ATTR_EMULATE_PREPARES => false, PDO::ATTR_PERSISTENT => true, PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION ); try { $conn = new PDO($dsn,$this->mUser,$this->mPass,$options); //prepare SQL varaibles $sEmail = $oAccount->Email(); $sEmailUser = \MailSo\Base\Utils::GetAccountNameFromEmail($sEmail); $sEmailDomain = \MailSo\Base\Utils::GetDomainFromEmail($sEmail); //simple check $old = array(':email', ':oldpass', ':newpass', ':domain', ':username', ':table' ); $new = array($sEmail, $sPrevPassword, $sNewPassword, $sEmailDomain, $sEmailUser, $this->mTable); $this->mSql = str_replace($old, $new, $this->mSql); $update = $conn->prepare($this->mSql); $mSqlReturn = $update->execute(array()); if ($mSqlReturn == true) { $bResult = true; if ($this->oLogger) { $this->oLogger->Write('Success! Password changed.'); } } else { $bResult = false; if ($this->oLogger) { $this->oLogger->Write('Something went wrong. Either current password is incorrect, or new password does not match criteria.'); } } } catch (\Exception $oException) { $bResult = false; if ($this->oLogger) { $this->oLogger->WriteException($oException); } } return $bResult; } }