LoginController.php 1.46 KB
<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;

class LoginController extends Controller
{
    public function __construct() {
        $this->middleware('guest')->except('logout');
    }

    //Форма входа
    public function login() {
        return view('auth.login');
    }

    // Аутентификация
    public function autenticate(Request $request) {
        $request->validate([
            'email' => 'required|string|email',
            'password' => 'required|string',
        ]);

        $credentials = $request->only('email', 'password');

        if (Auth::attempt($credentials, $request->has('remember'))) {
            if (is_null(Auth::user()->email_verified_at)){
                Auth::logout();
                return redirect()
                    ->route('auth.vefiry-message')
                    ->withErrors('Адрес почты не подтвержден');
            }

            return redirect()
                ->route('user.index')
                ->with('success', 'Вы вошли в личный кабинет.');
        }

        return redirect()
            ->route('auth.login')
            ->withErrors('Неверный логин или пароль!');
    }

    // Выход
    public function logout() {
        Auth::logout();
        return redirect()->route('index')
            ->with('success', 'Вы вышли из личного кабинета');
    }
}