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.
		
		
		
		
		
			
		
			
				
					
					
						
							95 lines
						
					
					
						
							2.4 KiB
						
					
					
				
			
		
		
	
	
							95 lines
						
					
					
						
							2.4 KiB
						
					
					
				| <?php | |
|  | |
| 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; | |
|  | |
| class AuthController extends Controller | |
| { | |
|     private $_auth_service; | |
|  | |
|     public function __construct($id, $module, AuthService $service, $config = []) | |
|     { | |
|         parent::__construct($id, $module, $config); | |
|         $this->_auth_service = $service; | |
|     } | |
|  | |
|     /** | |
|      * @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, | |
|                 '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 { | |
|                 $user = $this->_auth_service->auth($form); | |
|                 Yii::$app->user->login(new Identity($user), $form->rememberMe ? 3600 * 24 * 30 : 0); | |
|  | |
|                 return $this->goBack(); | |
|             } catch (\DomainException $e) { | |
|                 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(); | |
|     } | |
| }
 | |
| 
 |