point-tools/src/Repository/SubscriptionEventRepository...

135 lines
3.7 KiB
PHP
Raw Normal View History

2015-06-23 09:38:43 +00:00
<?php
declare(strict_types=1);
2015-06-23 09:38:43 +00:00
namespace App\Repository;
2015-06-23 09:38:43 +00:00
use App\DTO\DailyEventsDTO;
use App\Entity\SubscriptionEvent;
use App\Entity\User;
use Doctrine\Bundle\DoctrineBundle\Repository\ServiceEntityRepository;
use Doctrine\ORM\QueryBuilder;
use Doctrine\Persistence\ManagerRegistry;
/**
* @extends ServiceEntityRepository<SubscriptionEvent>
*
* @method SubscriptionEvent|null find($id, $lockMode = null, $lockVersion = null)
* @method SubscriptionEvent|null findOneBy(array $criteria, array $orderBy = null)
* @method SubscriptionEvent[] findAll()
* @method SubscriptionEvent[] findBy(array $criteria, array $orderBy = null, $limit = null, $offset = null)
*/
class SubscriptionEventRepository extends ServiceEntityRepository
2015-06-23 09:38:43 +00:00
{
public function __construct(ManagerRegistry $registry)
{
parent::__construct($registry, SubscriptionEvent::class);
}
public function save(SubscriptionEvent $entity, bool $flush = false): void
{
$this->getEntityManager()->persist($entity);
if ($flush) {
$this->getEntityManager()->flush();
}
}
public function getLastDayEventsCount(): int
2015-06-23 09:38:43 +00:00
{
$qb = $this->createQueryBuilder('se');
$from = (new \DateTime())->sub(new \DateInterval('PT24H'));
2015-06-23 09:38:43 +00:00
2015-06-23 09:42:59 +00:00
return $qb
2015-06-23 09:38:43 +00:00
->select('COUNT(se)')
->where('se.date > :from_time')
->setParameter('from_time', $from)
2015-06-23 09:38:43 +00:00
->getQuery()->getSingleScalarResult()
;
}
2015-06-23 10:34:53 +00:00
/** Creates QueryBuilder object for pagination of user subscribers events */
public function createUserLastSubscribersEventsQuery(User $user): QueryBuilder
2015-06-23 10:34:53 +00:00
{
$qb = $this->createQueryBuilder('se');
return $qb
->select(['se', 's'])
->join('se.subscriber', 's')
2015-06-23 10:34:53 +00:00
->where('se.author = :author')
->orderBy('se.date', 'desc')
->setParameter('author', $user->getId())
2015-06-23 10:34:53 +00:00
;
}
2015-06-23 11:03:46 +00:00
/**
* Get last user subscriber events
*
* @return SubscriptionEvent[]
*/
public function getUserLastSubscribersEvents(User $user, int $limit = 20): array
{
$qb = $this->createUserLastSubscribersEventsQuery($user);
$qb->setMaxResults($limit);
return $qb->getQuery()->getResult();
}
/** Get last global subscriptions QueryBuilder for pagination */
public function createLastSubscriptionEventsQuery(): QueryBuilder
2015-06-23 11:03:46 +00:00
{
$qb = $this->createQueryBuilder('se');
return $qb
2016-12-10 23:55:28 +00:00
->select(['se', 'a', 's'])
->innerJoin('se.author', 'a')
->innerJoin('se.subscriber', 's')
2015-06-23 11:03:46 +00:00
->orderBy('se.date', 'desc')
;
}
2017-01-04 22:36:30 +00:00
/**
* Get last global subscription events
*
* @return SubscriptionEvent[]
*/
public function getLastSubscriptionEvents(int $limit = 20): array
2017-01-04 22:36:30 +00:00
{
$qb = $this->createLastSubscriptionEventsQuery();
$qb->setMaxResults($limit);
return $qb->getQuery()->getResult();
}
/** @return DailyEventsDTO[] */
public function getLastEventsByDay(int $days = 30): array
{
$qb = $this->createQueryBuilder('se');
$rows = $qb
->select([
'NEW App\DTO\DailyEventsDTO(DAY(se.date), COUNT(se))',
'DAY(se.date) as day',
])
->groupBy('day')
->orderBy('day', 'DESC')
->setMaxResults($days)
->getQuery()->getResult()
;
$result = [];
// Removing unnecessary element, saving DTO
// @todo remove crutches, refactor query
foreach ($rows as $row) {
unset($row['day']);
$result[] = reset($row);
}
$result = array_reverse($result);
return $result;
}
}