HEX
Server: Apache/2
System: Linux s01 6.1.0-34-amd64 #1 SMP PREEMPT_DYNAMIC Debian 6.1.135-1 (2025-04-25) x86_64
User: beestg (1003)
PHP: 8.3.25
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: /home/beestg/public_html/wp-content/plugins/mailpoet/lib/Segments/SegmentsFinder.php
<?php declare(strict_types = 1);

namespace MailPoet\Segments;

if (!defined('ABSPATH')) exit;


use MailPoet\Entities\SegmentEntity;
use MailPoet\Entities\SubscriberEntity;
use MailPoet\Segments\DynamicSegments\FilterHandler;
use MailPoetVendor\Doctrine\DBAL\Result;
use MailPoetVendor\Doctrine\ORM\EntityManager;

class SegmentsFinder {
  /** @var EntityManager */
  private $entityManager;

  /** @var FilterHandler */
  private $filterHandler;

  /** @var SegmentsRepository */
  private $segmentsRepository;

  public function __construct(
    EntityManager $entityManager,
    FilterHandler $filterHandler,
    SegmentsRepository $segmentsRepository
  ) {
    $this->entityManager = $entityManager;
    $this->filterHandler = $filterHandler;
    $this->segmentsRepository = $segmentsRepository;
  }

  /** @return SegmentEntity[] */
  public function findSegments(SubscriberEntity $subscriber): array {
    return array_merge(
      $this->findStaticSegments($subscriber),
      $this->findDynamicSegments($subscriber)
    );
  }

  /** @return SegmentEntity[] */
  public function findStaticSegments(SubscriberEntity $subscriber): array {
    return $subscriber->getSegments()->toArray();
  }

  /** @return SegmentEntity[] */
  public function findDynamicSegments(SubscriberEntity $subscriber): array {
    $segments = $this->segmentsRepository->findBy([
      'type' => SegmentEntity::TYPE_DYNAMIC,
    ]);

    $subscribersTable = $this->entityManager->getClassMetadata(SubscriberEntity::class)->getTableName();
    $queryBuilder = $this->entityManager->getConnection()->createQueryBuilder()
      ->select('id')
      ->from($subscribersTable)
      ->where('id = :subscriberId')
      ->setParameter('subscriberId', $subscriber->getId());

    $matchingSegments = [];
    foreach ($segments as $segment) {
      $result = $this->filterHandler->apply(clone $queryBuilder, $segment)->execute();
      if ($result instanceof Result && $result->fetchOne()) {
        $matchingSegments[] = $segment;
      }
    }
    return $matchingSegments;
  }
}