has('multiple_contacts')) { return $next($request); } $multiple_contacts = ClientContact::query() ->with('client.gateway_tokens', 'company') ->where('email', auth()->guard('contact')->user()->email) ->whereNotNull('email') ->where('email', '<>', '') ->distinct('client_id') ->whereNotNull('company_id') ->whereHas('client', function ($query) { return $query->where('is_deleted', false); }) ->whereHas('company', function ($query) { return $query->where('companies.account_id', auth()->guard('contact')->user()->company->account_id); }) ->get(); /* This catches deleted clients who don't have access to the app. We automatically log them out here*/ if (count($multiple_contacts) == 0) { Auth::logout(); return redirect()->route('client.login')->with('message', 'Login disabled'); } if (count($multiple_contacts) == 1 && ! Auth::guard('contact')->check()) { Auth::guard('contact')->loginUsingId($multiple_contacts[0]->id, true); } session()->put('multiple_contacts', $multiple_contacts); session()->put('is_silent', request()->has('silent')); return $next($request); } }