LoginController.php 2.9 KB

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