public function userValidator() { if (!$this->hasErrors()) { $user = User::find()->active()->andWhere(['email' => $this->email])->limit(1)->one(); /* @var $user \api\v1\models\User */ if (!$user || !$user->validatePassword($this->password)) { $this->addError('password', 'Wrong auth data.'); return false; } $this->_user = $user; return true; } }
public function beforeAction($action) { Yii::$app->response->format = 'json'; $token = call_user_func(function () { $headers = Yii::$app->request->headers; return isset($headers['token']) ? $headers['token'] : null; }); if (!$token) { Yii::$app->response->data = ['status' => false, 'error' => 'NO_TOKEN', 'error_code' => 'NO_TOKEN']; return false; } $user = User::find()->active()->withToken($token)->one(); if (!$user) { Yii::$app->response->data = ['status' => false, 'error' => 'WRONG_TOKEN', 'error_code' => 'WRONG_TOKEN']; return false; } $this->_user = $user; return parent::beforeAction($action); }