From 7e609c293e97e71b179ceff41433d365a6a23da5 Mon Sep 17 00:00:00 2001 From: Joris Langlois Date: Fri, 27 Mar 2020 16:47:19 +0100 Subject: [PATCH 1/3] Add a publish endpoint --- config/packages/security.yaml | 2 +- config/routes.yaml | 7 +++ config/services/bus.yaml | 1 + config/services/command_handlers.yaml | 5 ++ .../Controller/ArticleController.php | 16 ++++++ src/Application/Controller/Endpoint.php | 3 ++ src/Domain/Command/Handler/PublishArticle.php | 49 +++++++++++++++++++ src/Domain/Command/PublishArticle.php | 21 ++++++++ .../Exception/ResourceNotFoundException.php | 10 ++++ src/Domain/Model/Article.php | 7 +++ 10 files changed, 120 insertions(+), 1 deletion(-) create mode 100644 src/Domain/Command/Handler/PublishArticle.php create mode 100644 src/Domain/Command/PublishArticle.php create mode 100644 src/Domain/Exception/ResourceNotFoundException.php diff --git a/config/packages/security.yaml b/config/packages/security.yaml index ac96a76..cd4405c 100644 --- a/config/packages/security.yaml +++ b/config/packages/security.yaml @@ -17,4 +17,4 @@ security: access_control: - { path: '^/', roles: IS_AUTHENTICATED_ANONYMOUSLY, methods: [GET] } - - { path: '^/', roles: ROLE_ADMIN, methods: [POST] } + - { path: '^/', roles: ROLE_ADMIN, methods: [PATCH, POST] } diff --git a/config/routes.yaml b/config/routes.yaml index 1ac273c..cb3cdc8 100644 --- a/config/routes.yaml +++ b/config/routes.yaml @@ -14,3 +14,10 @@ create_article: path: /articles methods: [POST] controller: App\Application\Controller\ArticleController::create + +publish_article: + path: /articles/{id}/publish + methods: [PATCH] + controller: App\Application\Controller\ArticleController::publish + requirements: + id: '[\d]+' diff --git a/config/services/bus.yaml b/config/services/bus.yaml index 715751a..f6408e2 100644 --- a/config/services/bus.yaml +++ b/config/services/bus.yaml @@ -5,3 +5,4 @@ services: - '@App\Domain\Command\Handler\ReadArticle' - '@App\Domain\Command\Handler\ListArticles' - '@App\Domain\Command\Handler\WriteArticle' + - '@App\Domain\Command\Handler\PublishArticle' diff --git a/config/services/command_handlers.yaml b/config/services/command_handlers.yaml index f6060b6..98c5ba2 100644 --- a/config/services/command_handlers.yaml +++ b/config/services/command_handlers.yaml @@ -14,3 +14,8 @@ services: arguments: - '@doctrine.orm.entity_manager' - '@Ausi\SlugGenerator\SlugGenerator' + + App\Domain\Command\Handler\PublishArticle: + arguments: + - '@doctrine.orm.entity_manager' + - '@App\Application\Repository\ArticleRepository' diff --git a/src/Application/Controller/ArticleController.php b/src/Application/Controller/ArticleController.php index f52a60a..7c348ac 100644 --- a/src/Application/Controller/ArticleController.php +++ b/src/Application/Controller/ArticleController.php @@ -107,4 +107,20 @@ public function create(Request $request): JsonResponse Response::HTTP_CREATED ); } + + // @todo add swager doc here + public function publish(int $id): JsonResponse + { + try { + $article = $this->bus->executeCommand(new Command\PublishArticle($id)); + } + catch (Exception $exception) { + return new JsonResponse( + ["error" => $exception->getMessage()], + Response::HTTP_INTERNAL_SERVER_ERROR + ); + } + + return new JsonResponse(new ArticleDefinition($article)); + } } diff --git a/src/Application/Controller/Endpoint.php b/src/Application/Controller/Endpoint.php index ad21fcc..adcdbde 100644 --- a/src/Application/Controller/Endpoint.php +++ b/src/Application/Controller/Endpoint.php @@ -3,10 +3,13 @@ namespace App\Application\Controller; use Symfony\Component\HttpFoundation\JsonResponse; +use Symfony\Component\HttpFoundation\Request; interface Endpoint { public function list(): JsonResponse; public function read(string $slug): JsonResponse; + + public function create(Request $request): JsonResponse; } diff --git a/src/Domain/Command/Handler/PublishArticle.php b/src/Domain/Command/Handler/PublishArticle.php new file mode 100644 index 0000000..1107d9f --- /dev/null +++ b/src/Domain/Command/Handler/PublishArticle.php @@ -0,0 +1,49 @@ +manager = $manager; + $this->repository = $repository; + } + + /** + * @throws ResourceNotFoundException + */ + public function __invoke(PublishArticleCommand $command): Article + { + $article = $this->repository->find($command->getId()); + + if (null === $article) { + throw new ResourceNotFoundException(); + } + + $article->publish(); + + $this->manager->persist($article); + $this->manager->flush(); + + return $article; + } +} diff --git a/src/Domain/Command/PublishArticle.php b/src/Domain/Command/PublishArticle.php new file mode 100644 index 0000000..8d9c782 --- /dev/null +++ b/src/Domain/Command/PublishArticle.php @@ -0,0 +1,21 @@ +id = $id; + } + + public function getId(): int + { + return $this->id; + } +} diff --git a/src/Domain/Exception/ResourceNotFoundException.php b/src/Domain/Exception/ResourceNotFoundException.php new file mode 100644 index 0000000..bb926c7 --- /dev/null +++ b/src/Domain/Exception/ResourceNotFoundException.php @@ -0,0 +1,10 @@ +draft = false; + + return $this; + } + public function getId(): int { return $this->id; From f4bd20df2340895e324f4ccac282c8c5201e11c1 Mon Sep 17 00:00:00 2001 From: Joris Langlois Date: Wed, 24 Jun 2020 17:42:21 +0200 Subject: [PATCH 2/3] fixed publish article handler --- src/Domain/Command/Handler/PublishArticle.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Domain/Command/Handler/PublishArticle.php b/src/Domain/Command/Handler/PublishArticle.php index 1107d9f..b389819 100644 --- a/src/Domain/Command/Handler/PublishArticle.php +++ b/src/Domain/Command/Handler/PublishArticle.php @@ -2,7 +2,7 @@ namespace App\Domain\Command\Handler; -use App\Domain\Article; +use App\Domain\Model\Article; use App\Domain\Command\PublishArticle as PublishArticleCommand; use App\Domain\Exception\ResourceNotFoundException; use App\Domain\Repository\ArticleRepository; From 9efcb60c563dcc00e0088313d4b2711322b702a8 Mon Sep 17 00:00:00 2001 From: Joris Langlois Date: Wed, 24 Jun 2020 18:33:50 +0200 Subject: [PATCH 3/3] use FQN notation for services --- config/services/command_handlers.yaml | 4 ++-- config/services/endpoints.yaml | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/config/services/command_handlers.yaml b/config/services/command_handlers.yaml index 98c5ba2..81e8308 100644 --- a/config/services/command_handlers.yaml +++ b/config/services/command_handlers.yaml @@ -12,10 +12,10 @@ services: App\Domain\Command\Handler\WriteArticle: arguments: - - '@doctrine.orm.entity_manager' + - '@Doctrine\ORM\EntityManagerInterface' - '@Ausi\SlugGenerator\SlugGenerator' App\Domain\Command\Handler\PublishArticle: arguments: - - '@doctrine.orm.entity_manager' + - '@Doctrine\ORM\EntityManagerInterface' - '@App\Application\Repository\ArticleRepository' diff --git a/config/services/endpoints.yaml b/config/services/endpoints.yaml index fb3150c..ea49a92 100644 --- a/config/services/endpoints.yaml +++ b/config/services/endpoints.yaml @@ -2,6 +2,6 @@ services: App\Application\Controller\ArticleController: arguments: - '@App\Domain\Command\Bus\SimpleBus' - - '@form.factory' + - '@Symfony\Component\Form\FormFactoryInterface' tags: - 'controller.service_arguments'