@@ -37,29 +37,29 @@ discard block |
||
37 | 37 | |
38 | 38 | class ArticleController extends AbstractController { |
39 | 39 | |
40 | - private FormFactoryInterface $formFactory; |
|
41 | - private RouteProviderInterface $routeProvider; // swp.provider.route |
|
42 | - private ArticleRepositoryInterface $articleRepository; //swp.repository.article |
|
43 | - private ArticleProviderInterface $articleProvider; //swp.provider.article |
|
44 | - private EventDispatcherInterface $eventDispatcher; |
|
45 | - private EntityManagerInterface $entityManager; // swp.object_manager.article |
|
46 | - private ArticleServiceInterface $articleService; // swp.service.article |
|
47 | - private PackageRepositoryInterface $packageRepository; |
|
48 | - |
|
49 | - /** |
|
50 | - * @param FormFactoryInterface $formFactory |
|
51 | - * @param RouteProviderInterface $routeProvider |
|
52 | - * @param ArticleRepositoryInterface $articleRepository |
|
53 | - * @param ArticleProviderInterface $articleProvider |
|
54 | - * @param EventDispatcherInterface $eventDispatcher |
|
55 | - * @param EntityManagerInterface $entityManager |
|
56 | - * @param ArticleServiceInterface $articleService |
|
57 | - * @param PackageRepositoryInterface $packageRepository |
|
58 | - */ |
|
59 | - public function __construct(FormFactoryInterface $formFactory, RouteProviderInterface $routeProvider, |
|
60 | - ArticleRepositoryInterface $articleRepository, ArticleProviderInterface $articleProvider, |
|
61 | - EventDispatcherInterface $eventDispatcher, EntityManagerInterface $entityManager, |
|
62 | - ArticleServiceInterface $articleService, PackageRepositoryInterface $packageRepository) { |
|
40 | + private FormFactoryInterface $formFactory; |
|
41 | + private RouteProviderInterface $routeProvider; // swp.provider.route |
|
42 | + private ArticleRepositoryInterface $articleRepository; //swp.repository.article |
|
43 | + private ArticleProviderInterface $articleProvider; //swp.provider.article |
|
44 | + private EventDispatcherInterface $eventDispatcher; |
|
45 | + private EntityManagerInterface $entityManager; // swp.object_manager.article |
|
46 | + private ArticleServiceInterface $articleService; // swp.service.article |
|
47 | + private PackageRepositoryInterface $packageRepository; |
|
48 | + |
|
49 | + /** |
|
50 | + * @param FormFactoryInterface $formFactory |
|
51 | + * @param RouteProviderInterface $routeProvider |
|
52 | + * @param ArticleRepositoryInterface $articleRepository |
|
53 | + * @param ArticleProviderInterface $articleProvider |
|
54 | + * @param EventDispatcherInterface $eventDispatcher |
|
55 | + * @param EntityManagerInterface $entityManager |
|
56 | + * @param ArticleServiceInterface $articleService |
|
57 | + * @param PackageRepositoryInterface $packageRepository |
|
58 | + */ |
|
59 | + public function __construct(FormFactoryInterface $formFactory, RouteProviderInterface $routeProvider, |
|
60 | + ArticleRepositoryInterface $articleRepository, ArticleProviderInterface $articleProvider, |
|
61 | + EventDispatcherInterface $eventDispatcher, EntityManagerInterface $entityManager, |
|
62 | + ArticleServiceInterface $articleService, PackageRepositoryInterface $packageRepository) { |
|
63 | 63 | $this->formFactory = $formFactory; |
64 | 64 | $this->routeProvider = $routeProvider; |
65 | 65 | $this->articleRepository = $articleRepository; |
@@ -68,30 +68,30 @@ discard block |
||
68 | 68 | $this->entityManager = $entityManager; |
69 | 69 | $this->articleService = $articleService; |
70 | 70 | $this->packageRepository = $packageRepository; |
71 | - } |
|
71 | + } |
|
72 | 72 | |
73 | 73 | |
74 | - /** |
|
75 | - * @Route("/api/{version}/content/articles/", methods={"GET"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_list_articles") |
|
76 | - * |
|
77 | - * @throws \Exception |
|
78 | - */ |
|
79 | - public function listAction(Request $request): ResourcesListResponseInterface { |
|
74 | + /** |
|
75 | + * @Route("/api/{version}/content/articles/", methods={"GET"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_list_articles") |
|
76 | + * |
|
77 | + * @throws \Exception |
|
78 | + */ |
|
79 | + public function listAction(Request $request): ResourcesListResponseInterface { |
|
80 | 80 | $authors = ''; |
81 | 81 | if (null !== $request->query->get('author', null)) { |
82 | - $authors = explode(', ', $request->query->get('author')); |
|
82 | + $authors = explode(', ', $request->query->get('author')); |
|
83 | 83 | } |
84 | 84 | |
85 | 85 | if ($request->query->get('route', false) && $request->query->get('includeSubRoutes', false)) { |
86 | - $routeObject = $this->routeProvider->getOneById($request->query->get('route')); |
|
86 | + $routeObject = $this->routeProvider->getOneById($request->query->get('route')); |
|
87 | 87 | |
88 | - if (null !== $routeObject) { |
|
88 | + if (null !== $routeObject) { |
|
89 | 89 | $ids = [$routeObject->getId()]; |
90 | 90 | foreach ($routeObject->getChildren() as $child) { |
91 | - $ids[] = $child->getId(); |
|
91 | + $ids[] = $child->getId(); |
|
92 | 92 | } |
93 | 93 | $request->query->set('route', $ids); |
94 | - } |
|
94 | + } |
|
95 | 95 | } |
96 | 96 | |
97 | 97 | $articles = $this->articleRepository |
@@ -106,31 +106,31 @@ discard block |
||
106 | 106 | ]), $request->query->all('sorting'), new PaginationData($request)); |
107 | 107 | |
108 | 108 | return new ResourcesListResponse($articles); |
109 | - } |
|
109 | + } |
|
110 | 110 | |
111 | - /** |
|
112 | - * @Route("/api/{version}/content/articles/{id}", methods={"GET"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_show_articles", requirements={"id"=".+"}) |
|
113 | - */ |
|
114 | - public function getAction($id): SingleResourceResponseInterface { |
|
111 | + /** |
|
112 | + * @Route("/api/{version}/content/articles/{id}", methods={"GET"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_show_articles", requirements={"id"=".+"}) |
|
113 | + */ |
|
114 | + public function getAction($id): SingleResourceResponseInterface { |
|
115 | 115 | $article = $this->articleProvider->getOneById($id); |
116 | 116 | |
117 | 117 | if (null === $article) { |
118 | - throw new NotFoundHttpException('Article was not found'); |
|
118 | + throw new NotFoundHttpException('Article was not found'); |
|
119 | 119 | } |
120 | 120 | |
121 | 121 | return new SingleResourceResponse($article); |
122 | - } |
|
122 | + } |
|
123 | 123 | |
124 | - /** |
|
125 | - * @Route("/api/{version}/content/article/search-code", methods={"GET"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_show_articles_by_code", requirements={"code"=".+"}) |
|
126 | - */ |
|
127 | - public function getByCodeAction(Request $request): SingleResourceResponseInterface { |
|
124 | + /** |
|
125 | + * @Route("/api/{version}/content/article/search-code", methods={"GET"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_show_articles_by_code", requirements={"code"=".+"}) |
|
126 | + */ |
|
127 | + public function getByCodeAction(Request $request): SingleResourceResponseInterface { |
|
128 | 128 | // Extract parameters from the request |
129 | 129 | $code = $request->query->get('code', ''); |
130 | 130 | $article = $this->articleRepository->findOneBy(['code' => $code]); |
131 | 131 | |
132 | 132 | if (null === $article) { |
133 | - throw new NotFoundHttpException('Article was not found'); |
|
133 | + throw new NotFoundHttpException('Article was not found'); |
|
134 | 134 | } |
135 | 135 | |
136 | 136 | $article->setStatus('new'); |
@@ -151,12 +151,12 @@ discard block |
||
151 | 151 | } |
152 | 152 | |
153 | 153 | return new SingleResourceResponse($article); |
154 | - } |
|
154 | + } |
|
155 | 155 | |
156 | - /** |
|
157 | - * @Route("/api/{version}/content/articles/{id}", methods={"PATCH"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_update_articles", requirements={"id"=".+"}) |
|
158 | - */ |
|
159 | - public function updateAction(Request $request, $id): SingleResourceResponseInterface { |
|
156 | + /** |
|
157 | + * @Route("/api/{version}/content/articles/{id}", methods={"PATCH"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_update_articles", requirements={"id"=".+"}) |
|
158 | + */ |
|
159 | + public function updateAction(Request $request, $id): SingleResourceResponseInterface { |
|
160 | 160 | $objectManager = $this->entityManager; |
161 | 161 | $article = $this->findOr404($id); |
162 | 162 | $originalArticleStatus = $article->getStatus(); |
@@ -165,32 +165,32 @@ discard block |
||
165 | 165 | |
166 | 166 | $form->handleRequest($request); |
167 | 167 | if ($form->isSubmitted() && $form->isValid()) { |
168 | - $this->articleService->reactOnStatusChange($originalArticleStatus, $article); |
|
169 | - $objectManager->flush(); |
|
170 | - $objectManager->refresh($article); |
|
168 | + $this->articleService->reactOnStatusChange($originalArticleStatus, $article); |
|
169 | + $objectManager->flush(); |
|
170 | + $objectManager->refresh($article); |
|
171 | 171 | |
172 | - return new SingleResourceResponse($article); |
|
172 | + return new SingleResourceResponse($article); |
|
173 | 173 | } |
174 | 174 | |
175 | 175 | return new SingleResourceResponse($form, new ResponseContext(500)); |
176 | - } |
|
176 | + } |
|
177 | 177 | |
178 | - /** |
|
179 | - * @Route("/api/{version}/content/articles/{id}", methods={"DELETE"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_delete_articles", requirements={"id"=".+"}) |
|
180 | - */ |
|
181 | - public function deleteAction($id): SingleResourceResponseInterface { |
|
178 | + /** |
|
179 | + * @Route("/api/{version}/content/articles/{id}", methods={"DELETE"}, options={"expose"=true}, defaults={"version"="v2"}, name="swp_api_content_delete_articles", requirements={"id"=".+"}) |
|
180 | + */ |
|
181 | + public function deleteAction($id): SingleResourceResponseInterface { |
|
182 | 182 | $objectManager = $this->entityManager; |
183 | 183 | $objectManager->remove($this->findOr404($id)); |
184 | 184 | $objectManager->flush(); |
185 | 185 | |
186 | 186 | return new SingleResourceResponse(null, new ResponseContext(204)); |
187 | - } |
|
187 | + } |
|
188 | 188 | |
189 | - private function findOr404($id) { |
|
189 | + private function findOr404($id) { |
|
190 | 190 | if (null === $article = $this->articleProvider->getOneById($id)) { |
191 | - throw new NotFoundHttpException('Article was not found.'); |
|
191 | + throw new NotFoundHttpException('Article was not found.'); |
|
192 | 192 | } |
193 | 193 | |
194 | 194 | return $article; |
195 | - } |
|
195 | + } |
|
196 | 196 | } |