%PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : 49.231.201.246 / Your IP : 216.73.216.149 Web Server : Apache/2.4.18 (Ubuntu) System : Linux 246 4.4.0-210-generic #242-Ubuntu SMP Fri Apr 16 09:57:56 UTC 2021 x86_64 User : root ( 0) PHP Version : 7.0.33-0ubuntu0.16.04.16 Disable Function : exec,passthru,shell_exec,system,proc_open,popen,pcntl_exec MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : ON | Pkexec : ON Directory : /proc/11584/root/var/www/html/ppaobm/vendor/mdmsoft/yii2-admin/models/form/ |
Upload File : |
<?php namespace mdm\admin\models\form; use mdm\admin\components\UserStatus; use mdm\admin\models\User; use Yii; use yii\base\InvalidParamException; use yii\base\Model; use yii\helpers\ArrayHelper; /** * Password reset form */ class ResetPassword extends Model { public $password; public $retypePassword; /** * @var User */ private $_user; /** * Creates a form model given a token. * * @param string $token * @param array $config name-value pairs that will be used to initialize the object properties * @throws InvalidParamException if token is empty or not valid */ public function __construct($token, $config = []) { if (empty($token) || !is_string($token)) { throw new InvalidParamException('Password reset token cannot be blank.'); } // check token $class = Yii::$app->getUser()->identityClass ?: 'mdm\admin\models\User'; if (static::isPasswordResetTokenValid($token)) { $this->_user = $class::findOne([ 'password_reset_token' => $token, 'status' => UserStatus::ACTIVE ]); } if (!$this->_user) { throw new InvalidParamException('Wrong password reset token.'); } parent::__construct($config); } /** * @inheritdoc */ public function rules() { return [ [['password', 'retypePassword'], 'required'], ['password', 'string', 'min' => 6], ['retypePassword', 'compare', 'compareAttribute' => 'password'] ]; } /** * Resets password. * * @return boolean if password was reset. */ public function resetPassword() { $user = $this->_user; $user->setPassword($this->password); $user->removePasswordResetToken(); return $user->save(false); } /** * Finds out if password reset token is valid * * @param string $token password reset token * @return boolean */ public static function isPasswordResetTokenValid($token) { if (empty($token)) { return false; } $expire = ArrayHelper::getValue(Yii::$app->params, 'user.passwordResetTokenExpire', 24 * 3600); $parts = explode('_', $token); $timestamp = (int) end($parts); return $timestamp + $expire >= time(); } }