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;
|
||||
|
||||
use App\Exceptions\BadRequestException;
|
||||
use App\Node\UseCases\BulkCreateNodesRequest;
|
||||
use App\Node\NodeRepository;
|
||||
use App\Node\UseCases\BulkCreateNodes;
|
||||
|
|
@ -47,17 +48,10 @@ class NodeController
|
|||
CreateNode $createNodeUseCase,
|
||||
): Response {
|
||||
$data = json_decode((string) $request->getBody(), true) ?? [];
|
||||
$title = $data['title'] ?? '';
|
||||
|
||||
if (empty($title)) {
|
||||
$response->getBody()->write(json_encode(['error' => 'Title is required']));
|
||||
return $response->withStatus(400)->withHeader('Content-Type', 'application/json');
|
||||
}
|
||||
|
||||
$textId = (int) ($data['textId'] ?? 0);
|
||||
$parentNodeId = isset($data['parentNodeId']) && $data['parentNodeId'] !== null
|
||||
? (int) $data['parentNodeId']
|
||||
: null;
|
||||
$textId = isset($data['textId']) ? (int) $data['textId'] : null;
|
||||
$title = $data['title'] ?? null;
|
||||
$parentNodeId = isset($data['parentNodeId']) ? (int) $data['parentNodeId'] : null;
|
||||
|
||||
try {
|
||||
$node = $createNodeUseCase->execute(new CreateNodeRequest(
|
||||
|
|
@ -65,6 +59,9 @@ class NodeController
|
|||
title: $title,
|
||||
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) {
|
||||
$response->getBody()->write(json_encode(['error' => $e->getMessage()]));
|
||||
return $response->withStatus(404)->withHeader('Content-Type', 'application/json');
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue