1
0
mirror of https://github.com/flarum/core.git synced 2025-07-23 09:41:26 +02:00

Move some API error handling code around. It still sucks though

This commit is contained in:
Toby Zerner
2015-05-07 16:08:20 +09:30
parent a79dcf69b2
commit 59562b3246
4 changed files with 22 additions and 27 deletions

View File

@@ -3,8 +3,12 @@
use Flarum\Api\Request; use Flarum\Api\Request;
use Flarum\Api\JsonApiRequest; use Flarum\Api\JsonApiRequest;
use Flarum\Api\JsonApiResponse; use Flarum\Api\JsonApiResponse;
use Flarum\Core\Exceptions\ValidationFailureException;
use Flarum\Core\Exceptions\PermissionDeniedException;
use Tobscure\JsonApi\SerializerInterface; use Tobscure\JsonApi\SerializerInterface;
use Tobscure\JsonApi\Criteria; use Tobscure\JsonApi\Criteria;
use Illuminate\Http\Response;
use Illuminate\Http\JsonResponse;
abstract class SerializeAction implements ActionInterface abstract class SerializeAction implements ActionInterface
{ {
@@ -68,7 +72,20 @@ abstract class SerializeAction implements ActionInterface
{ {
$request = static::buildJsonApiRequest($request); $request = static::buildJsonApiRequest($request);
$data = $this->data($request, $response = new JsonApiResponse); try {
$data = $this->data($request, $response = new JsonApiResponse);
} catch (ValidationFailureException $e) {
$errors = [];
foreach ($e->getErrors()->getMessages() as $field => $messages) {
$errors[] = [
'detail' => implode("\n", $messages),
'path' => $field
];
}
return new JsonResponse(['errors' => $errors], 422);
} catch (PermissionDeniedException $e) {
return new JsonResponse(null, 401);
}
$serializer = new static::$serializer($request->actor, $request->include, $request->link); $serializer = new static::$serializer($request->actor, $request->include, $request->link);

View File

@@ -3,6 +3,7 @@
use Flarum\Api\Request; use Flarum\Api\Request;
use Flarum\Core\Commands\GenerateAccessTokenCommand; use Flarum\Core\Commands\GenerateAccessTokenCommand;
use Flarum\Core\Repositories\UserRepositoryInterface; use Flarum\Core\Repositories\UserRepositoryInterface;
use Flarum\Core\Exceptions\PermissionDeniedException;
use Illuminate\Http\JsonResponse; use Illuminate\Http\JsonResponse;
use Illuminate\Contracts\Bus\Dispatcher; use Illuminate\Contracts\Bus\Dispatcher;
@@ -32,9 +33,8 @@ class TokenAction implements ActionInterface
$user = $this->users->findByIdentification($identification); $user = $this->users->findByIdentification($identification);
if (! $user || ! $user->checkPassword($password)) { if (! $user || ! $user->checkPassword($password)) {
return; // throw new PermissionDeniedException;
// throw an exception return new JsonResponse(null, 401);
// return $this->respondWithError('invalidCredentials', 401);
} }
$token = $this->bus->dispatch( $token = $this->bus->dispatch(

View File

@@ -5,8 +5,6 @@ use Illuminate\Foundation\Exceptions\Handler;
use Illuminate\Http\Response; use Illuminate\Http\Response;
use Illuminate\Http\JsonResponse; use Illuminate\Http\JsonResponse;
use Illuminate\Database\Eloquent\ModelNotFoundException; use Illuminate\Database\Eloquent\ModelNotFoundException;
use Flarum\Core\Exceptions\ValidationFailureException;
use Flarum\Core\Exceptions\PermissionDeniedException;
use Symfony\Component\HttpKernel\Exception\HttpException; use Symfony\Component\HttpKernel\Exception\HttpException;
use Config; use Config;
@@ -31,13 +29,6 @@ class ExceptionHandler extends Handler
public function render($request, Exception $e) public function render($request, Exception $e)
{ {
if ($request->is('api/*')) { if ($request->is('api/*')) {
if ($e instanceof ValidationFailureException) {
return $this->renderValidationException($e);
}
if ($e instanceof PermissionDeniedException) {
return new Response(null, 401);
}
$error = []; $error = [];
if (Config::get('app.debug')) { if (Config::get('app.debug')) {
$error['code'] = (new \ReflectionClass($e))->getShortName(); $error['code'] = (new \ReflectionClass($e))->getShortName();
@@ -60,16 +51,4 @@ class ExceptionHandler extends Handler
{ {
return new JsonResponse(['errors' => $errors], $httpCode); return new JsonResponse(['errors' => $errors], $httpCode);
} }
protected function renderValidationException(ValidationFailureException $e)
{
$errors = [];
foreach ($e->getErrors()->getMessages() as $field => $messages) {
$errors[] = [
'detail' => implode("\n", $messages),
'path' => $field
];
}
return $this->renderErrors($errors, 422);
}
} }

View File

@@ -21,8 +21,7 @@ class LoginAction extends BaseAction
$response = app('Flarum\Api\Actions\TokenAction') $response = app('Flarum\Api\Actions\TokenAction')
->handle(new ApiRequest($request->only('identification', 'password'))); ->handle(new ApiRequest($request->only('identification', 'password')));
$data = $response->getData(); if (($data = $response->getData()) && ! empty($data->token)) {
if (! empty($data->token)) {
$response->withCookie($this->makeRememberCookie($data->token)); $response->withCookie($this->makeRememberCookie($data->token));
event(new UserLoggedIn($this->users->findOrFail($data->userId), $data->token)); event(new UserLoggedIn($this->users->findOrFail($data->userId), $data->token));