LoginController.php 2.36 KB
<?php

namespace App\Http\Controllers\Auth;

use App\Http\Controllers\Controller;
use App\Providers\RouteServiceProvider;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;

class LoginController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Login Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles authenticating users for the application and
    | redirecting them to your home screen. The controller uses a trait
    | to conveniently provide its functionality to your applications.
    |
    */

    use AuthenticatesUsers;

    /**
     * Where to redirect users after login.
     *
     * @var string
     */
    protected $redirectTo = RouteServiceProvider::HOME;

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest')->except('logout');
    }

    public function showLoginForm()
    {
        return view('auth.login');
    }

    public function login(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('login')
                    ->withErrors('Адрес почты не подтвержден');
            }

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

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

    protected function authenticated(Request $request, $user) {
        return redirect()->route('home')
            ->with('success', 'Вы успешно вошли в кабинет');
    }

    protected function loggedOut(Request $request) {
        return redirect()->route('login')
            ->with('success', 'Вы успешно вышли из кабинета');
    }


}