summaryrefslogtreecommitdiff
path: root/src/Controller/Login.php
diff options
context:
space:
mode:
authorDaniel Weipert <git@mail.dweipert.de>2024-01-02 20:42:01 +0100
committerDaniel Weipert <git@mail.dweipert.de>2024-01-05 12:33:59 +0100
commitb21316248572cb27ed1f504529ad6680a473022e (patch)
treef8a2f81258cae3b1d2429fb7df5a3287954b683a /src/Controller/Login.php
parentf621d95f89ded05a2e916c5ee363bfe75ea37482 (diff)
gemini
Diffstat (limited to 'src/Controller/Login.php')
-rw-r--r--src/Controller/Login.php53
1 files changed, 0 insertions, 53 deletions
diff --git a/src/Controller/Login.php b/src/Controller/Login.php
deleted file mode 100644
index 0f360ae..0000000
--- a/src/Controller/Login.php
+++ /dev/null
@@ -1,53 +0,0 @@
-<?php
-
-namespace App\Controller;
-
-use App\DB;
-use App\View;
-use Symfony\Component\HttpFoundation\RedirectResponse;
-use Symfony\Component\HttpFoundation\Request;
-use Symfony\Component\HttpFoundation\Response;
-use Symfony\Component\Routing\Annotation\Route;
-
-class Login
-{
- #[Route(path: '/login', methods: ['GET'])]
- public function form(Request $request): Response
- {
- return new Response(View::render('login.twig'));
- }
-
- #[Route(path: '/login', methods: ['POST'])]
- public function login(Request $request): Response
- {
- $email = $request->get('email');
- $user = DB::query('select id,username,password from users where email=:email', ['email' => $email])->fetch();
-
- if (empty($user)) {
- $password = password_hash($request->get('password'), PASSWORD_DEFAULT);
- DB::query('insert into users (username, password, email) values (:username, :password, :email)', ['username' => $email, 'password' => $password, 'email' => $email]);
- } else {
- $password = $user['password'];
- }
-
- if (password_verify($request->get('password'), $password)) {
- $_SESSION['user'] = [
- 'id' => $user['id'],
- 'username' => $user['username'],
- ];
-
- return new RedirectResponse('/villages');
- }
-
- return new RedirectResponse('/login');
- }
-
- #[Route(path: '/logout', methods: ['GET'])]
- public function logout(Request $request): Response
- {
- session_unset();
- session_destroy();
-
- return new RedirectResponse('/login');
- }
-}