username)])->first(); if (! $user || ! Hash::check($request->password, $user->password)) { throw ValidationException::withMessages([ 'email' => ['The provided credentials are incorrect.'], ]); } // Auto-accept invitation if token is provided if ($request->has('invitation_token') && $request->invitation_token) { $invitation = CompanyInvitation::where('token', $request->invitation_token) ->pending() ->first(); if ($invitation) { app(InvitationService::class)->accept($invitation, $user); } } return response()->json([ 'type' => 'Bearer', 'token' => $user->createToken($request->device_name)->plainTextToken, ]); } public function logout(Request $request) { $request->user()->currentAccessToken()->delete(); return response()->json([ 'success' => true, ]); } public function check() { return Auth::check(); } }