mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-10-06 11:45:48 +08:00
try to plug the hole in the custom sql plugin
This commit is contained in:
parent
95eb786a3f
commit
b17e5dd11d
1 changed files with 35 additions and 7 deletions
|
@ -146,7 +146,7 @@ class ChangePasswordCustomSqlDriver implements \RainLoop\Providers\ChangePasswor
|
||||||
|
|
||||||
$dsn = 'mysql:host='.$this->mHost.';dbname='.$this->mDatabase.';charset=utf8';
|
$dsn = 'mysql:host='.$this->mHost.';dbname='.$this->mDatabase.';charset=utf8';
|
||||||
$options = array(
|
$options = array(
|
||||||
PDO::ATTR_EMULATE_PREPARES => false,
|
PDO::ATTR_EMULATE_PREPARES => true,
|
||||||
PDO::ATTR_PERSISTENT => true,
|
PDO::ATTR_PERSISTENT => true,
|
||||||
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
|
PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
|
||||||
);
|
);
|
||||||
|
@ -160,15 +160,43 @@ class ChangePasswordCustomSqlDriver implements \RainLoop\Providers\ChangePasswor
|
||||||
$sEmailUser = \MailSo\Base\Utils::GetAccountNameFromEmail($sEmail);
|
$sEmailUser = \MailSo\Base\Utils::GetAccountNameFromEmail($sEmail);
|
||||||
$sEmailDomain = \MailSo\Base\Utils::GetDomainFromEmail($sEmail);
|
$sEmailDomain = \MailSo\Base\Utils::GetDomainFromEmail($sEmail);
|
||||||
|
|
||||||
//simple check
|
// some variables cannot be prepared
|
||||||
|
/*
|
||||||
|
$this->mSql = str_replace(array(
|
||||||
|
':table'
|
||||||
|
), array(
|
||||||
|
$this->mTable
|
||||||
|
), $this->mSql);
|
||||||
|
*/
|
||||||
|
|
||||||
$old = array(':email', ':oldpass', ':newpass', ':domain', ':username', ':table' );
|
$placeholders = array(
|
||||||
$new = array($sEmail, $sPrevPassword, $sNewPassword, $sEmailDomain, $sEmailUser, $this->mTable);
|
':table' => $this->mTable,
|
||||||
|
':email' => $sEmail,
|
||||||
|
':oldpass' => $sPrevPassword,
|
||||||
|
':newpass' => $sNewPassword,
|
||||||
|
':domain' => $sEmailDomain,
|
||||||
|
':username' => $sEmailUser
|
||||||
|
);
|
||||||
|
|
||||||
$this->mSql = str_replace($old, $new, $this->mSql);
|
$statement = $conn->prepare($this->mSql);
|
||||||
|
|
||||||
|
$this->oLogger->Write($this->mSql);
|
||||||
|
|
||||||
|
$statement->bindValue(':table', 'accounts');
|
||||||
|
$statement->bindValue(':email', $sEmail);
|
||||||
|
$statement->bindValue(':oldpass', $sPrevPassword);
|
||||||
|
$statement->bindValue(':newpass', $sNewPassword);
|
||||||
|
$statement->bindValue(':domain', $sEmailDomain);
|
||||||
|
$statement->bindValue(':username', $sEmailUser);
|
||||||
|
|
||||||
|
$mSqlReturn = $statement->execute();
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
$statement->debugDumpParams();
|
||||||
|
$r = ob_get_contents();
|
||||||
|
ob_end_clean();
|
||||||
|
$this->oLogger->Write($r);
|
||||||
|
|
||||||
$update = $conn->prepare($this->mSql);
|
|
||||||
$mSqlReturn = $update->execute(array());
|
|
||||||
if ($mSqlReturn == true)
|
if ($mSqlReturn == true)
|
||||||
{
|
{
|
||||||
$bResult = true;
|
$bResult = true;
|
||||||
|
|
Loading…
Add table
Reference in a new issue