LoginController.php 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. <?php
  2. /*
  3. * LoginController — авторизация администраторов в панели управления.
  4. *
  5. * Создан: 2026-05-06
  6. * Маршруты: GET /admin/login → showLoginForm()
  7. * POST /admin/login → login()
  8. * POST /admin/logout → logout()
  9. *
  10. * Вход по email (стандартный способ Laravel Auth).
  11. * После успешной авторизации проверяется флаг is_admin: если false — сессия сбрасывается.
  12. */
  13. namespace App\Http\Controllers\Admin;
  14. use App\Http\Controllers\Controller;
  15. use Illuminate\Http\RedirectResponse;
  16. use Illuminate\Http\Request;
  17. use Illuminate\Support\Facades\Auth;
  18. use Illuminate\View\View;
  19. class LoginController extends Controller
  20. {
  21. // Форма входа; если уже авторизован как admin — редирект на дашборд
  22. // Вьюха: resources/views/admin/login.blade.php
  23. public function showLoginForm(): View|RedirectResponse
  24. {
  25. if (Auth::check() && Auth::user()->is_admin) {
  26. return redirect()->route('admin.dashboard');
  27. }
  28. return view('admin.login');
  29. }
  30. // Обработка формы входа
  31. // Auth::attempt(['email' => ...]) — стандартный способ Laravel через email
  32. // После входа проверяется is_admin: если false — немедленный Auth::logout()
  33. // session()->regenerate() — защита от session fixation атаки
  34. // redirect()->intended() — редирект на URL куда шёл до входа, иначе на дашборд
  35. public function login(Request $request): RedirectResponse
  36. {
  37. $request->validate([
  38. 'email' => ['required', 'email'],
  39. 'password' => ['required', 'string'],
  40. ]);
  41. $credentials = [
  42. 'email' => $request->email,
  43. 'password' => $request->password,
  44. ];
  45. if (Auth::attempt($credentials, $request->boolean('remember'))) {
  46. if (Auth::user()->is_admin) {
  47. $request->session()->regenerate();
  48. return redirect()->intended(route('admin.dashboard'));
  49. }
  50. Auth::logout();
  51. }
  52. return back()->withErrors([
  53. 'email' => 'Неверный email или пароль.',
  54. ])->onlyInput('email');
  55. }
  56. // Выход: invalidate() уничтожает сессию, regenerateToken() обновляет CSRF-токен
  57. public function logout(Request $request): RedirectResponse
  58. {
  59. Auth::logout();
  60. $request->session()->invalidate();
  61. $request->session()->regenerateToken();
  62. return redirect()->route('admin.login');
  63. }
  64. }