ActivePageRepository.php 3.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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 findActivePagesAndPageCreatetors()
  27. {
  28. $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable('pages');
  29. $queryBuilder->getRestrictions()->removeAll();
  30. $statement = $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(12, \PDO::PARAM_INT)),
  43. $queryBuilder->expr()->eq('p.deleted', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT)),
  44. $queryBuilder->expr()->eq('p.hidden', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT))
  45. )
  46. ->groupBy('p.slug')
  47. ->orderBy('p.endtime', 'ASC');
  48. $result = $statement->execute();
  49. return $result->fetchAllAssociative();
  50. }
  51. public function findExpiredRecordsInTheLast30OR90Days(int $daysPast = 0)
  52. {
  53. $currentDate = new \DateTime("now");
  54. $timestampToday = $currentDate->getTimestamp();
  55. $period = ($daysPast == 30) ? 'P30D' : 'P90D';
  56. $timeperiod = $currentDate->sub(new \DateInterval($period));
  57. $timestamp = $timeperiod->getTimestamp();
  58. $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)->getQueryBuilderForTable('pages');
  59. $queryBuilder->getRestrictions()->removeAll(); // Remove all restrictions
  60. $queryBuilder
  61. ->select('p.uid', 'p.starttime', 'p.endtime', 'p.title', 'p.roof', 'p.slug', 'u.username', 'u.realName')
  62. ->from('pages', 'p')
  63. ->leftJoin(
  64. 'p',
  65. 'be_users',
  66. 'u',
  67. $queryBuilder->expr()->eq('p.cruser_id', $queryBuilder->quoteIdentifier('u.uid'))
  68. )
  69. ->where(
  70. $queryBuilder->expr()->gt('p.starttime', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT)),
  71. $queryBuilder->expr()->eq('p.red_status', $queryBuilder->createNamedParameter(22, \PDO::PARAM_INT)),
  72. $queryBuilder->expr()->eq('p.deleted', $queryBuilder->createNamedParameter(0, \PDO::PARAM_INT)),
  73. $queryBuilder->expr()->eq('p.hidden', $queryBuilder->createNamedParameter(1, \PDO::PARAM_INT))
  74. )
  75. ->andWhere(
  76. $queryBuilder->expr()->gte('p.endtime', $queryBuilder->createNamedParameter($timestamp, \PDO::PARAM_INT)),
  77. $queryBuilder->expr()->lte('p.endtime', $queryBuilder->createNamedParameter($timestampToday, \PDO::PARAM_INT))
  78. )
  79. ->groupBy('p.slug')
  80. ->orderBy('p.endtime', 'ASC');
  81. return $queryBuilder->execute()->fetchAllAssociative();
  82. }
  83. }