refactor create node controller to catch BadRequestException
This commit is contained in:
parent
38b7a0adb8
commit
1761bfad7f
1 changed files with 7 additions and 10 deletions
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
namespace App\Node;
|
namespace App\Node;
|
||||||
|
|
||||||
|
use App\Exceptions\BadRequestException;
|
||||||
use App\Node\UseCases\BulkCreateNodesRequest;
|
use App\Node\UseCases\BulkCreateNodesRequest;
|
||||||
use App\Node\NodeRepository;
|
use App\Node\NodeRepository;
|
||||||
use App\Node\UseCases\BulkCreateNodes;
|
use App\Node\UseCases\BulkCreateNodes;
|
||||||
|
|
@ -47,17 +48,10 @@ class NodeController
|
||||||
CreateNode $createNodeUseCase,
|
CreateNode $createNodeUseCase,
|
||||||
): Response {
|
): Response {
|
||||||
$data = json_decode((string) $request->getBody(), true) ?? [];
|
$data = json_decode((string) $request->getBody(), true) ?? [];
|
||||||
$title = $data['title'] ?? '';
|
|
||||||
|
|
||||||
if (empty($title)) {
|
$textId = isset($data['textId']) ? (int) $data['textId'] : null;
|
||||||
$response->getBody()->write(json_encode(['error' => 'Title is required']));
|
$title = $data['title'] ?? null;
|
||||||
return $response->withStatus(400)->withHeader('Content-Type', 'application/json');
|
$parentNodeId = isset($data['parentNodeId']) ? (int) $data['parentNodeId'] : null;
|
||||||
}
|
|
||||||
|
|
||||||
$textId = (int) ($data['textId'] ?? 0);
|
|
||||||
$parentNodeId = isset($data['parentNodeId']) && $data['parentNodeId'] !== null
|
|
||||||
? (int) $data['parentNodeId']
|
|
||||||
: null;
|
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$node = $createNodeUseCase->execute(new CreateNodeRequest(
|
$node = $createNodeUseCase->execute(new CreateNodeRequest(
|
||||||
|
|
@ -65,6 +59,9 @@ class NodeController
|
||||||
title: $title,
|
title: $title,
|
||||||
parentNodeId: $parentNodeId,
|
parentNodeId: $parentNodeId,
|
||||||
));
|
));
|
||||||
|
} catch (BadRequestException $e) {
|
||||||
|
$response->getBody()->write(json_encode(['error' => $e->getMessage()]));
|
||||||
|
return $response->withStatus(400)->withHeader('Content-Type', 'application/json');
|
||||||
} catch (DomainException $e) {
|
} catch (DomainException $e) {
|
||||||
$response->getBody()->write(json_encode(['error' => $e->getMessage()]));
|
$response->getBody()->write(json_encode(['error' => $e->getMessage()]));
|
||||||
return $response->withStatus(404)->withHeader('Content-Type', 'application/json');
|
return $response->withStatus(404)->withHeader('Content-Type', 'application/json');
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue