<?php
namespace App\Http\Controllers\Coaching\Auth;
session_start();

use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\AuthenticatesUsers;
use Illuminate\Validation\ValidationException;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use App\Models\CoachingMaster;
use File;

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 = '/coaching-master/dashboard';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('coaching.guest')->except('logout');
    }

    public function showLoginForm()
    {
        return view('coaching.auth.login');
    }

    public function logout(Request $request)
    {
        // dd(Auth::user());
        session_destroy();
        $this->guard()->logout();
        return redirect('/coaching-master/login');
    }

    protected function guard()
    {
        return Auth::guard('coaching');
    }

    protected function attemptLogin(Request $request)
    {
        $dataCredential = $this->credentials($request);
        $dataCredential['status'] = '0';
        return $this->guard()->attempt(
            $dataCredential, $request->filled('remember')
        );
        
    }

    protected function authenticated(Request $request, $user)
    {
        $user = CoachingMaster::find(Auth::guard('coaching')->user()->coaching_id);
        $_SESSION["myRoxySession"] = "../Uploads/".Auth::guard('coaching')->user()->coaching_id;
        $path = public_path().'/fileman/Uploads/' . Auth::guard('coaching')->user()->coaching_id;
        if (!file_exists($path)) {
            File::makeDirectory($path, $mode = 0777, true, true);
        }
        if ($user->status == 2) {
            session_destroy();
            $this->guard()->logout();
            
           throw ValidationException::withMessages([
                $this->username() => [trans('auth.banned')],
            ]); 
            
            return redirect('/coaching-master/login');
        }

    }
}
