/** * Sends an email with a link, for resetting the password. * * @return boolean whether the email was send */ public function sendEmail() { /* @var $user User */ $user = User::findOne(['status' => User::STATUS_ACTIVE, 'email' => $this->email]); if ($user) { $token = UserToken::create($user->id, UserToken::TYPE_PASSWORD_RESET, Time::SECONDS_IN_A_DAY); if ($user->save()) { return Yii::$app->commandBus->handle(new SendEmailCommand(['to' => $this->email, 'subject' => Yii::t('frontend', 'Password reset for {name}', ['name' => Yii::$app->name]), 'view' => 'passwordResetToken', 'params' => ['user' => $user, 'token' => $token->token]])); } } return false; }
/** * Signs user up. * * @return User|null the saved model or null if saving fails */ public function signup() { if ($this->validate()) { $shouldBeActivated = $this->shouldBeActivated(); $user = new User(); $user->username = $this->username; $user->email = $this->email; $user->is_activated = !$shouldBeActivated; $user->setPassword($this->password); $user->save(); $user->afterSignup(); if ($shouldBeActivated) { $token = UserToken::create($user->id, UserToken::TYPE_ACTIVATION, Time::SECONDS_IN_A_DAY); Yii::$app->commandBus->handle(new SendEmailCommand(['subject' => Yii::t('frontend', 'Activation email'), 'view' => 'activation', 'params' => ['url' => Url::to(['/user/sign-in/activation', 'token' => $token->token], true)]])); } return $user; } return null; }