|
4 | 4 |
|
5 | 5 | namespace PhpList\Core\Domain\Repository\Subscription; |
6 | 6 |
|
| 7 | +use InvalidArgumentException; |
| 8 | +use PhpList\Core\Domain\Filter\FilterRequestInterface; |
| 9 | +use PhpList\Core\Domain\Filter\SubscriberFilter; |
7 | 10 | use PhpList\Core\Domain\Model\Subscription\Subscriber; |
8 | 11 | use PhpList\Core\Domain\Repository\AbstractRepository; |
9 | 12 | use PhpList\Core\Domain\Repository\CursorPaginationTrait; |
@@ -44,6 +47,29 @@ public function getSubscribersBySubscribedListId(int $listId): array |
44 | 47 | ->getResult(); |
45 | 48 | } |
46 | 49 |
|
| 50 | + /** |
| 51 | + * @return Subscriber[] |
| 52 | + * @throws InvalidArgumentException |
| 53 | + */ |
| 54 | + public function getFilteredAfterId(int $lastId, int $limit, ?FilterRequestInterface $filter = null): array |
| 55 | + { |
| 56 | + if (!$filter instanceof SubscriberFilter) { |
| 57 | + throw new InvalidArgumentException('Expected SubscriberFilterRequest.'); |
| 58 | + } |
| 59 | + |
| 60 | + $alias = $this->getAlias(); |
| 61 | + |
| 62 | + $queryBuilder = $this->createQueryBuilder($alias) |
| 63 | + ->innerJoin($alias . '.subscriptions', 'subscription') |
| 64 | + ->innerJoin('subscription.subscriberList', 'list'); |
| 65 | + if ($filter->getListId() !== null) { |
| 66 | + $queryBuilder->where('list.id = :listId') |
| 67 | + ->setParameter('listId', $filter->getListId()); |
| 68 | + } |
| 69 | + |
| 70 | + return $this->getAfterId($queryBuilder, $lastId, $limit); |
| 71 | + } |
| 72 | + |
47 | 73 | public function findSubscriberWithSubscriptions(int $id): ?Subscriber |
48 | 74 | { |
49 | 75 | return $this->createQueryBuilder('s') |
|
0 commit comments