public function rules() { return [['username', 'filter', 'filter' => 'trim'], ['username', 'required'], ['username', 'string', 'min' => 3, 'max' => 20], ['username', 'match', 'pattern' => '/^[A-Za-z0-9_]+$/u', 'message' => "Логин должен состоять только из латинских букв и цифр без пробелов"], ['password', 'required'], ['password', function () { $this->user = User::findByUsername($this->username); if (is_null($this->user) or !$this->user->validatePassword($this->password)) { $this->addError('password', 'Неверный логин или пароль'); } }]]; }
public function signup() { if ($this->validate()) { $user = new User(); $user->setAttributes($this->attributes, false); $user->setPassword($this->password); $user->generateAuthKey(); $user->status = User::STATUS_ACTIVE; if ($user->save(false)) { $role = Yii::$app->authManager->getRole('User'); Yii::$app->authManager->assign($role, $user->id); return true; } } return false; }
public function onAuthSuccess($client) { $attributes = $client->getUserAttributes(); // var_dump($attributes); exit; /* @var $auth Auth */ $auth = Auth::find()->where(['source' => $client->getId(), 'source_id' => $attributes['id']])->one(); if (Yii::$app->user->isGuest) { if ($auth) { // авторизация $user = $auth->user; Yii::$app->user->login($user); } else { // регистрация if (isset($attributes['email']) && User::find()->where(['email' => $attributes['email']])->exists()) { Yii::$app->getSession()->setFlash('error', [Yii::t('app', "Пользователь с такой электронной почтой как в {client} уже существует, но с ним не связан. Для начала войдите на сайт использую электронную почту, для того, что бы связать её.", ['client' => $client->getTitle()])]); } else { $password = Yii::$app->security->generateRandomString(6); $user = new User(['username' => isset($attributes['login']) ? $attributes['login'] : isset($attributes['name']) ? $attributes['name'] : $attributes['first_name'] . $attributes['last_name'], 'password' => $password]); $user->status = 1; $user->generateAuthKey(); // $user->generatePasswordResetToken(); $transaction = $user->getDb()->beginTransaction(); if ($user->save()) { $auth = new Auth(['user_id' => $user->id, 'source' => $client->getId(), 'source_id' => (string) $attributes['id']]); if ($auth->save()) { $transaction->commit(); Yii::$app->user->login($user); } else { print_r($auth->getErrors()); } } else { print_r($user->getErrors()); } } } } else { // Пользователь уже зарегистрирован if (!$auth) { // добавляем внешний сервис аутентификации $auth = new Auth(['user_id' => Yii::$app->user->id, 'source' => $client->getId(), 'source_id' => $attributes['id']]); $auth->save(); } } }
public function actionSignup() { $signupForm = new SignupForm(); if (Yii::$app->request->isAjax && $signupForm->load(Yii::$app->request->post())) { Yii::$app->response->format = Response::FORMAT_JSON; return ActiveForm::validate($signupForm); } else { if ($signupForm->load(Yii::$app->getRequest()->post()) && $signupForm->signup()) { $user = User::findByUsername($signupForm->username); Yii::$app->user->login($user); return $this->goBack(); } } return $this->renderAjax('signup', ['model' => $signupForm]); }
public function getUser() { return $this->hasOne(User::className(), ['id' => 'user_id']); }