2016-08-21 04:51:39 +05:30
|
|
|
|
<?php
|
|
|
|
|
namespace api\modules\authserver\controllers;
|
|
|
|
|
|
|
|
|
|
use api\controllers\Controller;
|
|
|
|
|
use api\modules\authserver\models;
|
2017-05-31 05:40:22 +05:30
|
|
|
|
use Yii;
|
2016-08-21 04:51:39 +05:30
|
|
|
|
|
|
|
|
|
class AuthenticationController extends Controller {
|
|
|
|
|
|
2017-09-19 22:36:16 +05:30
|
|
|
|
public function behaviors(): array {
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$behaviors = parent::behaviors();
|
|
|
|
|
unset($behaviors['authenticator']);
|
|
|
|
|
|
|
|
|
|
return $behaviors;
|
|
|
|
|
}
|
|
|
|
|
|
2016-08-31 16:02:51 +05:30
|
|
|
|
public function verbs() {
|
|
|
|
|
return [
|
|
|
|
|
'authenticate' => ['POST'],
|
|
|
|
|
'refresh' => ['POST'],
|
|
|
|
|
'validate' => ['POST'],
|
|
|
|
|
'signout' => ['POST'],
|
|
|
|
|
'invalidate' => ['POST'],
|
|
|
|
|
];
|
|
|
|
|
}
|
|
|
|
|
|
2016-08-21 04:51:39 +05:30
|
|
|
|
public function actionAuthenticate() {
|
|
|
|
|
$model = new models\AuthenticationForm();
|
2017-05-31 05:40:22 +05:30
|
|
|
|
$model->load(Yii::$app->request->post());
|
2016-08-21 04:51:39 +05:30
|
|
|
|
|
|
|
|
|
return $model->authenticate()->getResponseData(true);
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-01 13:01:43 +05:30
|
|
|
|
public function actionRefresh() {
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$model = new models\RefreshTokenForm();
|
2017-05-31 05:40:22 +05:30
|
|
|
|
$model->load(Yii::$app->request->post());
|
2016-08-21 04:51:39 +05:30
|
|
|
|
|
|
|
|
|
return $model->refresh()->getResponseData(false);
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-01 13:01:43 +05:30
|
|
|
|
public function actionValidate() {
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$model = new models\ValidateForm();
|
2017-05-31 05:40:22 +05:30
|
|
|
|
$model->load(Yii::$app->request->post());
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$model->validateToken();
|
|
|
|
|
// В случае успеха ожидается пустой ответ. В случае ошибки же бросается исключение,
|
|
|
|
|
// которое обработает ErrorHandler
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-01 13:01:43 +05:30
|
|
|
|
public function actionSignout() {
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$model = new models\SignoutForm();
|
2017-05-31 05:40:22 +05:30
|
|
|
|
$model->load(Yii::$app->request->post());
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$model->signout();
|
|
|
|
|
// В случае успеха ожидается пустой ответ. В случае ошибки же бросается исключение,
|
|
|
|
|
// которое обработает ErrorHandler
|
|
|
|
|
}
|
|
|
|
|
|
2016-09-01 13:01:43 +05:30
|
|
|
|
public function actionInvalidate() {
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$model = new models\InvalidateForm();
|
2017-05-31 05:40:22 +05:30
|
|
|
|
$model->load(Yii::$app->request->post());
|
2016-08-21 04:51:39 +05:30
|
|
|
|
$model->invalidateToken();
|
|
|
|
|
// В случае успеха ожидается пустой ответ. В случае ошибки же бросается исключение,
|
|
|
|
|
// которое обработает ErrorHandler
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|