login
This commit is contained in:
		
							
								
								
									
										60
									
								
								kernel/controllers/SecureController.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								kernel/controllers/SecureController.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,60 @@ | ||||
| <?php | ||||
|  | ||||
| namespace kernel\controllers; | ||||
|  | ||||
| use JetBrains\PhpStorm\NoReturn; | ||||
| use kernel\AdminController; | ||||
| use kernel\helpers\Debug; | ||||
| use kernel\models\forms\LoginForm; | ||||
| use kernel\modules\user\service\UserService; | ||||
|  | ||||
| class SecureController extends AdminController | ||||
| { | ||||
|     protected UserService $userService; | ||||
|  | ||||
|     protected function init(): void | ||||
|     { | ||||
|         parent::init(); | ||||
|         $this->cgView->viewPath = KERNEL_DIR . "/views/secure/"; | ||||
|         $this->cgView->layout = "/login.php"; | ||||
|         $this->userService = new UserService(); | ||||
|     } | ||||
|  | ||||
|     public function actionLogin(): void | ||||
|     { | ||||
|         $this->cgView->render('login.php'); | ||||
|     } | ||||
|  | ||||
|     public function actionAuth(): void | ||||
|     { | ||||
|         $loginForm = new LoginForm(); | ||||
|         $loginForm->load($_REQUEST); | ||||
|  | ||||
|         if(filter_var($loginForm->getItem("username"), FILTER_VALIDATE_EMAIL)) { | ||||
|             $field = "email"; | ||||
|         } | ||||
|         else { | ||||
|             $field = "username"; | ||||
|         } | ||||
|  | ||||
|         $user = $this->userService->getByField($field, $loginForm->getItem("username")); | ||||
|         if (!$user){ | ||||
|             throw new \Exception(message: "User not found"); | ||||
|         } | ||||
|  | ||||
|         if (password_verify($loginForm->getItem("password"), $user->password_hash)) { | ||||
|             setcookie('user_id', $user->id, time()+60*60*24, '/', $_SERVER['SERVER_NAME'], false); | ||||
|             $this->redirect("/admin"); | ||||
|         } else { | ||||
|             $this->redirect("/admin/login"); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     #[NoReturn] public function actionLogout(): void | ||||
|     { | ||||
|         unset($_COOKIE['user_id']); | ||||
|         setcookie('user_id', "", time() - 3600, '/'); | ||||
|         $this->redirect("/"); | ||||
|     } | ||||
|  | ||||
| } | ||||
		Reference in New Issue
	
	Block a user