ArticleDao.php 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. <?php
  2. namespace internship\model;
  3. use n2n\persistence\orm\EntityManager;
  4. use internship\bo\Article;
  5. use n2n\context\attribute\RequestScoped;
  6. /**
  7. * Benutze diese Klasse um Datenbankabfragen auszuführen.
  8. * Du findest alle Informationen zu Datenbankabfragen in der Doku:
  9. * https://dev.n2n.rocks/de/n2n/docs/persistence-orm#entitymanager
  10. */
  11. #[RequestScoped]
  12. class ArticleDao {
  13. private EntityManager $em;
  14. private function _init(EntityManager $em): void {
  15. $this->em = $em;
  16. }
  17. /**
  18. * Gebe alle {@see Article}-Objekte, nach id absteigend sortiert, zurück.
  19. *
  20. * @return Article[]
  21. */
  22. function getArticles(): array {
  23. $criteria = $this->em->createSimpleCriteria(Article::class,
  24. null,
  25. array('id' => 'DESC'));
  26. return $criteria->toQuery()->fetchArray();
  27. }
  28. /**
  29. * Gebe alle {@see Article} zurück, welche dem übergebenen Kategorienamen entsprechen.
  30. *
  31. * @return array
  32. */
  33. function getArticlesByCategoryName(string $categoryName): array {
  34. $criteria = $this->em->createSimpleCriteria(Article::class,
  35. array('categoryName' => $categoryName),
  36. array('id' => 'DESC'));
  37. return $criteria->toQuery()->fetchArray();
  38. }
  39. /**
  40. * Gebe den {@see Article} mit der enstprechenden ID zurück.
  41. *
  42. * @param int $id
  43. * @return Article|null
  44. */
  45. function getArticleById(int $id): ?Article {
  46. return $this->em->find(Article::class, $id);
  47. }
  48. function saveArticle(Article $article) {
  49. $this->em->persist($article);
  50. }
  51. function removeArticle(int $articleId) {
  52. $this->em->remove($this->getArticleById($articleId));
  53. }
  54. }