ActivePageRepository.php 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. declare(strict_types=1);
  3. namespace Meramo\Pagemanager\Domain\Repository;
  4. use TYPO3\CMS\Extbase\Persistence\Repository;
  5. use \TYPO3\CMS\Extbase\Persistence\Generic\QueryResult;
  6. use TYPO3\CMS\Core\Database\ConnectionPool;
  7. use TYPO3\CMS\Core\Utility\GeneralUtility;
  8. /**
  9. * This file is part of the "ABI2021 Page Manager" Extension for TYPO3 CMS.
  10. *
  11. * For the full copyright and license information, please read the
  12. * LICENSE.txt file that was distributed with this source code.
  13. *
  14. * (c) 2023 Meramo Developer <development@meramo.de>, Meramo Verlag GmbH
  15. */
  16. /**
  17. * The repository for ActivePages
  18. */
  19. class ActivePageRepository extends Repository
  20. {
  21. /**
  22. * Queries the pages and be_users tables and returns the Data as an array
  23. *
  24. * @return QueryResult|array
  25. */
  26. public function findPages(int $redStatus, int $hiddenStatus, int $daysPast = 0, string $orderBy = 'ASC')
  27. {
  28. $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable('pages');
  29. $queryBuilder->getRestrictions()->removeAll(); // Remove all restrictions
  30. $query = $queryBuilder
  31. ->select('p.uid', 'p.starttime', 'p.endtime', 'p.title', 'p.roof', 'p.slug', 'u.username', 'u.realName')
  32. ->from('pages', 'p')
  33. ->leftJoin(
  34. 'p',
  35. 'be_users',
  36. 'u',
  37. $queryBuilder->expr()->eq('p.cruser_id', $queryBuilder->quoteIdentifier('u.uid'))
  38. )
  39. ->where(
  40. $queryBuilder->expr()->gt('p.starttime', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT)),
  41. $queryBuilder->expr()->gt('p.endtime', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT)),
  42. $queryBuilder->expr()->eq('p.red_status', $queryBuilder->createNamedParameter($redStatus, \PDO::PARAM_INT)),
  43. $queryBuilder->expr()->eq('p.deleted', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT)),
  44. $queryBuilder->expr()->eq('p.hidden', $queryBuilder->createNamedParameter($hiddenStatus, \PDO::PARAM_INT))
  45. )
  46. ->groupBy('p.slug')
  47. ->orderBy('p.endtime', $orderBy);
  48. if ($daysPast !== 0) {
  49. $currentDate = new \DateTime("now");
  50. $timestampToday = $currentDate->getTimestamp();
  51. $period = ($daysPast == 30) ? 'P30D' : 'P90D';
  52. $timeperiod = $currentDate->sub(new \DateInterval($period));
  53. $timestamp = $timeperiod->getTimestamp();
  54. $query->andWhere(
  55. $queryBuilder->expr()->gte('p.endtime', $queryBuilder->createNamedParameter($timestamp, \PDO::PARAM_INT)),
  56. $queryBuilder->expr()->lte('p.endtime', $queryBuilder->createNamedParameter($timestampToday, \PDO::PARAM_INT))
  57. );
  58. }
  59. return $query->execute()->fetchAllAssociative();
  60. }
  61. }