'trim'], ['email', 'required'], ['email', 'email'], [ 'email', 'exist', 'targetClass' => AdminUser::className(), 'filter' => ['status' => AdminUser::STATUS_ACTIVE], 'message' => yii::t('app', 'There is no user with such email.') ], ]; } /** * @inheritdoc */ public function attributeLabels() { return [ 'email' => yii::t('app', 'Email'), ]; } /** * Sends an email with a link, for resetting the password. * * @return boolean whether the email was send */ public function sendEmail() { /* @var $user AdminUser */ $user = AdminUser::findOne([ 'status' => AdminUser::STATUS_ACTIVE, 'email' => $this->email, ]); if (! $user) { return false; } if (! AdminUser::isPasswordResetTokenValid($user->password_reset_token)) { $user->generatePasswordResetToken(); } Event::off(BaseActiveRecord::className(), BaseActiveRecord::EVENT_AFTER_UPDATE); if (! $user->save()) { return false; } return Yii::$app->mailer->compose([ 'html' => 'backend/passwordResetToken-html', 'text' => 'backend/passwordResetToken-text' ], ['user' => $user]) ->setFrom(Yii::$app->mailer->messageConfig['from']) ->setTo($this->email) ->setSubject('Password reset for ' . Yii::$app->name) ->send(); } }