2016-02-27 01:22:09 +03:00
|
|
|
<?php
|
2016-05-14 02:47:17 +03:00
|
|
|
namespace api\models\profile;
|
2016-02-27 01:22:09 +03:00
|
|
|
|
2016-07-25 14:07:14 +03:00
|
|
|
use api\models\base\ApiForm;
|
|
|
|
use api\validators\PasswordRequiredValidator;
|
2016-06-16 23:32:23 +03:00
|
|
|
use common\helpers\Error as E;
|
2016-02-27 01:22:09 +03:00
|
|
|
use common\models\Account;
|
2016-11-01 23:59:43 +03:00
|
|
|
use common\validators\PasswordValidator;
|
2016-02-27 01:22:09 +03:00
|
|
|
use Yii;
|
2016-06-05 17:01:35 +03:00
|
|
|
use yii\base\ErrorException;
|
2016-03-20 23:33:09 +03:00
|
|
|
use yii\helpers\ArrayHelper;
|
2016-02-27 01:22:09 +03:00
|
|
|
|
2016-07-25 14:07:14 +03:00
|
|
|
class ChangePasswordForm extends ApiForm {
|
2016-02-27 01:22:09 +03:00
|
|
|
|
|
|
|
public $newPassword;
|
|
|
|
|
|
|
|
public $newRePassword;
|
|
|
|
|
2016-04-25 00:30:10 +03:00
|
|
|
public $logoutAll;
|
|
|
|
|
2016-07-25 14:07:14 +03:00
|
|
|
public $password;
|
|
|
|
|
2016-02-27 01:22:09 +03:00
|
|
|
/**
|
|
|
|
* @var \common\models\Account
|
|
|
|
*/
|
|
|
|
private $_account;
|
|
|
|
|
2016-06-05 17:01:35 +03:00
|
|
|
public function __construct(Account $account, array $config = []) {
|
|
|
|
$this->_account = $account;
|
|
|
|
parent::__construct($config);
|
|
|
|
}
|
|
|
|
|
2016-02-27 01:22:09 +03:00
|
|
|
/**
|
|
|
|
* @inheritdoc
|
|
|
|
*/
|
|
|
|
public function rules() {
|
2016-03-20 23:33:09 +03:00
|
|
|
return ArrayHelper::merge(parent::rules(), [
|
2016-06-16 23:32:23 +03:00
|
|
|
['newPassword', 'required', 'message' => E::NEW_PASSWORD_REQUIRED],
|
|
|
|
['newRePassword', 'required', 'message' => E::NEW_RE_PASSWORD_REQUIRED],
|
2016-11-01 23:59:43 +03:00
|
|
|
['newPassword', PasswordValidator::class],
|
2016-02-27 01:22:09 +03:00
|
|
|
['newRePassword', 'validatePasswordAndRePasswordMatch'],
|
2016-04-25 00:30:10 +03:00
|
|
|
['logoutAll', 'boolean'],
|
2016-07-25 14:07:14 +03:00
|
|
|
['password', PasswordRequiredValidator::class, 'account' => $this->_account],
|
2016-03-20 23:33:09 +03:00
|
|
|
]);
|
2016-02-27 01:22:09 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
public function validatePasswordAndRePasswordMatch($attribute) {
|
2016-05-02 13:11:10 +03:00
|
|
|
if (!$this->hasErrors($attribute)) {
|
2016-02-27 01:22:09 +03:00
|
|
|
if ($this->newPassword !== $this->newRePassword) {
|
2016-06-16 23:32:23 +03:00
|
|
|
$this->addError($attribute, E::NEW_RE_PASSWORD_DOES_NOT_MATCH);
|
2016-02-27 01:22:09 +03:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2016-07-25 14:07:14 +03:00
|
|
|
* @return bool
|
|
|
|
* @throws ErrorException
|
2016-02-27 01:22:09 +03:00
|
|
|
*/
|
2016-06-16 23:32:23 +03:00
|
|
|
public function changePassword() : bool {
|
2016-02-27 01:22:09 +03:00
|
|
|
if (!$this->validate()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2016-06-05 17:01:35 +03:00
|
|
|
$transaction = Yii::$app->db->beginTransaction();
|
2016-02-27 01:22:09 +03:00
|
|
|
$account = $this->_account;
|
|
|
|
$account->setPassword($this->newPassword);
|
|
|
|
|
2016-04-25 00:30:10 +03:00
|
|
|
if ($this->logoutAll) {
|
2017-02-23 02:01:32 +03:00
|
|
|
Yii::$app->user->terminateSessions();
|
2016-06-05 17:01:35 +03:00
|
|
|
}
|
|
|
|
|
2016-11-02 00:02:58 +03:00
|
|
|
if (!$account->save()) {
|
2016-06-05 17:01:35 +03:00
|
|
|
throw new ErrorException('Cannot save user model');
|
2016-04-25 00:30:10 +03:00
|
|
|
}
|
|
|
|
|
2016-06-05 17:01:35 +03:00
|
|
|
$transaction->commit();
|
|
|
|
|
|
|
|
return true;
|
2016-02-27 01:22:09 +03:00
|
|
|
}
|
|
|
|
|
2016-06-16 23:32:23 +03:00
|
|
|
protected function getAccount() : Account {
|
2016-03-20 23:33:09 +03:00
|
|
|
return $this->_account;
|
|
|
|
}
|
|
|
|
|
2016-02-27 01:22:09 +03:00
|
|
|
}
|