ArticleController.php 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <?php
  2. namespace internship\controller;
  3. use n2n\web\http\controller\ControllerAdapter;
  4. use internship\model\ArticleDao;
  5. use n2n\context\attribute\Inject;
  6. use n2n\web\http\controller\ParamBody;
  7. use internship\bo\Article;
  8. use n2n\web\http\PageNotFoundException;
  9. use n2n\web\http\BadRequestException;
  10. /**
  11. * REST Controller
  12. * https://dev.n2n.rocks/de/n2n/docs/rest
  13. */
  14. class ArticleController extends ControllerAdapter {
  15. #[Inject]
  16. private ArticleDao $articleDao;
  17. public function index() {
  18. echo 'hallo atusch';
  19. }
  20. /**
  21. * Gibt den {@see Article} mit der entsprechenden id im JSON Format zurück.
  22. *
  23. * <ul>
  24. * <li>
  25. * Gib "irgendöpis" mit dem {@code echo} command aus.
  26. * </li>
  27. * <li>
  28. * Ändere die Antwort nun zu einem gültigen json objekt {"hello" => "world"}. Übergebe dafür ein array der
  29. * Methode {@see $this->sendJson()}.
  30. * </li>
  31. * <li>
  32. * Implementiere und nutze die Methode {@see ArticleDao::getArticleById()}, um das entsprechende Artikel-Objekt
  33. * aus der Datenbank zu lesen und gebe diese anschliessend im JSON Format zurück.
  34. *
  35. * Das Article-Objekt kannst du einfach {@see $this->sendJson()} übergeben, um einen validen JSON-Response zu
  36. * generieren.
  37. * </li>
  38. * <li>
  39. * Kann der Artikel nicht gefunden werden, werfe eine {@link PageNotFoundException}.
  40. * </li>
  41. * </ul>
  42. *
  43. * @param int $articleId
  44. * @return void
  45. * @throws PageNotFoundException if Article could not be found.
  46. */
  47. function getDoArticle(int $articleId): void {
  48. $article = $this->articleDao->getArticleById($articleId);
  49. if ($article === null) {
  50. throw new PageNotFoundException('No Article with this id');
  51. }
  52. $this->sendJson($article);
  53. }
  54. /**
  55. * Diese Methode kannst du im Browser testen. Pfad: localhost/[ordner name vom projekt]/src-php/public/api/articles
  56. *
  57. * <ul>
  58. * <li>
  59. * Implementiere und nutze die Methode {@see ArticleDao::getArticles()}, um Artikel aus der Datenbank zu lesen
  60. * und gebe diese anschliessend im JSON Format zurück.
  61. *
  62. * Article-Objekte kannst du einfach {@see $this->sendJson()} übergeben, um einen validen JSON-Response zu
  63. * generieren.
  64. * </li>
  65. * <li>
  66. * Wird ein $categoryName übergeben, gebe nur die Artikel aus, die über diesen Kategorienamen verfügen.
  67. * </li>
  68. * </ul>
  69. *
  70. * @param string|null $categoryName
  71. * @return void
  72. */
  73. function getDoArticles(string $categoryName = null): void {
  74. if ($categoryName === null) {
  75. $articles = $this->articleDao->getArticles();
  76. } else {
  77. $articles = $this->articleDao->getArticlesByCategoryName($categoryName);
  78. }
  79. // if (empty($articles)) {
  80. // throw new PageNotFoundException('No such category // no Categories');
  81. // }
  82. $this->sendJson($articles);
  83. }
  84. /**
  85. * Speichere einen Artikel.
  86. *
  87. * <ul>
  88. * <li>
  89. * Der Kategoriename darf nur 'international','national' oder 'sport' sein.
  90. * Validiere dies und schmeisse im Fehlerfall eine: {@see BadRequestException}
  91. * </li>
  92. * <li>
  93. * Mache eine neue Entity {@see Article} und befülle sie mit den übergebenen Daten.
  94. * </li>
  95. * <li>
  96. * Implementiere eine neue Methode im {@see ArticleDao} und benenne sie "saveArticle".
  97. * </li>
  98. * </ul>
  99. *
  100. * Nenne die Methode {@see saveArticle(Article $article)}
  101. *
  102. * @return void
  103. */
  104. function postDoNewArticle(ParamBody $body): void {
  105. $articleData = $body->parseJson();
  106. if (!array_key_exists('title', $articleData)
  107. || !array_key_exists('text', $articleData)
  108. || !array_key_exists('categoryName', $articleData)) {
  109. throw new BadRequestException('param: title, text, or categoryName is missing');
  110. }
  111. if (empty($articleData['title']) || empty($articleData['text']) || empty($articleData['categoryName'])) {
  112. throw new BadRequestException('title, text, or categoryName is empty');
  113. }
  114. if (!in_array($articleData['categoryName'], ['international', 'national', 'sport'])) {
  115. throw new BadRequestException('invalid category name');
  116. }
  117. $article = new Article();
  118. $article->setTitle((substr_replace($articleData['title'], "", 255)));
  119. $article->setText($articleData['text']);
  120. $article->setCategoryName($articleData['categoryName']);
  121. $this->beginTransaction();
  122. $this->articleDao->saveArticle($article);
  123. $this->commit();
  124. $this->sendJson($article);
  125. }
  126. /**
  127. * Editiere einen Artikel.
  128. *
  129. * <ul>
  130. * <li>
  131. * Der Kategoriename darf nur 'international','national' oder 'sport' sein.
  132. * Validiere dies und schmeisse im Fehlerfall eine: {@see BadRequestException}
  133. * </li>
  134. * <li>
  135. * Finde den dazugehörigen {@see Article} und passe die Daten mit denjenigen Daten von gestern ab.
  136. * </li>
  137. * <li>
  138. * Implementiere eine neue Methode im {@see ArticleDao} und nenne die Methode {@see saveArticle(Article $article)}.
  139. * </li>
  140. * </ul>
  141. *
  142. * @return void
  143. */
  144. function putDoArticle(int $articleId, ParamBody $body): void {
  145. $articleObject = $this->articleDao->getArticleById($articleId);
  146. if (empty($articleObject)) {
  147. throw new PageNotFoundException('invalid article ID');
  148. }
  149. $article = $body->parseJson();
  150. if (array_key_exists('title', $article) && !empty($article['title'])) {
  151. $articleObject->setTitle((substr_replace($article['title'], "", 255)));
  152. }
  153. if (array_key_exists('text', $article) && !empty($article['text'])) {
  154. $articleObject->setText($article['text']);
  155. }
  156. if (array_key_exists('categoryName', $article) && !empty($article['categoryName'])) {
  157. if (!in_array($article['categoryName'], ['international', 'national', 'sport'])) {
  158. throw new BadRequestException('invalid category name');
  159. }
  160. $articleObject->setCategoryName($article['categoryName']);
  161. }
  162. $this->beginTransaction();
  163. $this->articleDao->saveArticle($articleObject);
  164. $this->commit();
  165. $this->sendJson($articleObject->jsonSerialize());
  166. }
  167. /**
  168. * Löscht den {@see Article} mit der dazugehörigen Id.
  169. *
  170. * <ul>
  171. * <li>Mache eine neue Methode im {@see ArticleDao} und benenne sie "removeArticle(int articleId) </li>
  172. * <ul>
  173. *
  174. * @return void
  175. */
  176. function deleteDoArticle(int $articleId): void {
  177. $articleObject = $this->articleDao->getArticleById($articleId);
  178. if (empty($articleObject)) {
  179. throw new PageNotFoundException('invalid article ID');
  180. }
  181. $this->beginTransaction();
  182. $this->articleDao->removeArticle($articleObject);
  183. $this->commit();
  184. }
  185. }