header('X-API-TOKEN') && ($company_token = CompanyToken::with(['user','company'])->whereRaw("BINARY `token`= ?", [$request->header('X-API-TOKEN')])->first())) { $user = $company_token->user; $error = [ 'message' => 'User inactive', 'errors' => new \stdClass ]; //user who once existed, but has been soft deleted if (!$user) { return response()->json($error, 403); } /* | | Necessary evil here: As we are authenticating on CompanyToken, | we need to link the company to the user manually. This allows | us to decouple a $user and their attached companies completely. | */ $user->setCompany($company_token->company); config(['ninja.company_id' => $company_token->company->id]); app('queue')->createPayloadUsing(function () use ($company_token) { return ['db' => $company_token->company->db]; }); //user who once existed, but has been soft deleted if ($user->company_user->is_locked) { $error = [ 'message' => 'User access locked', 'errors' => new \stdClass ]; return response()->json($error, 403); } //stateless, don't remember the user. auth()->login($user, false); event(new UserLoggedIn($user, $company_token->company, Ninja::eventVars())); } else { $error = [ 'message' => 'Invalid token', 'errors' => new \stdClass ]; return response()->json($error, 403); } return $next($request); } }