X-Git-Url: http://source.bookstackapp.com/bookstack/blobdiff_plain/3d11cba223cad16ad13faee010259e97b05dcee9..refs/pull/5676/head:/app/Http/Middleware/ApiAuthenticate.php diff --git a/app/Http/Middleware/ApiAuthenticate.php b/app/Http/Middleware/ApiAuthenticate.php index fffbd9ef6..5f3ad3168 100644 --- a/app/Http/Middleware/ApiAuthenticate.php +++ b/app/Http/Middleware/ApiAuthenticate.php @@ -8,49 +8,51 @@ use Illuminate\Http\Request; class ApiAuthenticate { - use ChecksForEmailConfirmation; - /** * Handle an incoming request. + * + * @throws ApiAuthException */ public function handle(Request $request, Closure $next) + { + // Validate the token and it's users API access + $this->ensureAuthorizedBySessionOrToken(); + + return $next($request); + } + + /** + * Ensure the current user can access authenticated API routes, either via existing session + * authentication or via API Token authentication. + * + * @throws ApiAuthException + */ + protected function ensureAuthorizedBySessionOrToken(): void { // Return if the user is already found to be signed in via session-based auth. // This is to make it easy to browser the API via browser after just logging into the system. - if (signedInUser()) { - if ($this->awaitingEmailConfirmation()) { - return $this->emailConfirmationErrorResponse($request); + if (!user()->isGuest() || session()->isStarted()) { + if (!$this->sessionUserHasApiAccess()) { + throw new ApiAuthException(trans('errors.api_user_no_api_permission'), 403); } - return $next($request); + + return; } // Set our api guard to be the default for this request lifecycle. auth()->shouldUse('api'); // Validate the token and it's users API access - try { - auth()->authenticate(); - } catch (ApiAuthException $exception) { - return $this->unauthorisedResponse($exception->getMessage(), $exception->getCode()); - } - - if ($this->awaitingEmailConfirmation()) { - return $this->emailConfirmationErrorResponse($request, true); - } - - return $next($request); + auth()->authenticate(); } /** - * Provide a standard API unauthorised response. + * Check if the active session user has API access. */ - protected function unauthorisedResponse(string $message, int $code) + protected function sessionUserHasApiAccess(): bool { - return response()->json([ - 'error' => [ - 'code' => $code, - 'message' => $message, - ] - ], 401); + $hasApiPermission = user()->can('access-api'); + + return $hasApiPermission && user()->hasAppAccess(); } }