You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

97 lines
2.4 KiB

7 years ago
<?php
7 years ago
namespace backend\controllers;
use common\auth\Identity;
use core\services\auth\AuthService;
use Yii;
use yii\web\Controller;
use yii\filters\VerbFilter;
use core\forms\auth\LoginForm;
use yii\filters\AccessControl;
use DomainException;
7 years ago
class AuthController extends Controller
{
6 years ago
private $auth_service;
7 years ago
public function __construct($id, $module, AuthService $service, $config = [])
{
parent::__construct($id, $module, $config);
6 years ago
$this->auth_service = $service;
7 years ago
}
/**
* @inheritdoc
*/
public function behaviors()
{
return [
'access' => [
'class' => AccessControl::class,
'rules' => [
[
'actions' => ['login'],
'allow' => true,
'roles' => ['?'],
],
[
'actions' => ['logout'],
'allow' => true,
'roles' => ['@'],
],
[ // all the action are accessible to admin
'allow' => true,
'roles' => ['admin'],
],
],
],
'verbs' => [
'class' => VerbFilter::class,
7 years ago
'actions' => [
'logout' => ['post'],
],
],
];
}
/**
* @return mixed
*/
public function actionLogin()
{
if (!Yii::$app->user->isGuest) {
return $this->goHome();
}
$this->layout = 'main-login';
$form = new LoginForm();
if ($form->load(Yii::$app->request->post()) && $form->validate()) {
try {
6 years ago
$user = $this->auth_service->auth($form);
7 years ago
Yii::$app->user->login(new Identity($user), $form->rememberMe ? 3600 * 24 * 30 : 0);
7 years ago
return $this->goBack();
} catch (DomainException $e) {
7 years ago
Yii::$app->errorHandler->logException($e);
Yii::$app->session->setFlash('error', $e->getMessage());
}
}
return $this->render('login', [
'model' => $form,
]);
}
/**
* @return mixed
*/
public function actionLogout()
{
Yii::$app->user->logout();
return $this->goHome();
}
}