Example #1
0
 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', 'Неверный логин или пароль');
         }
     }]];
 }
Example #2
0
 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;
 }
Example #3
0
 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();
         }
     }
 }
Example #4
0
 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]);
 }
Example #5
0
 public function getUser()
 {
     return $this->hasOne(User::className(), ['id' => 'user_id']);
 }