HEX
Server: Apache/2
System: Linux server-80-13-140-150.da.direct 5.14.0-362.24.1.el9_3.0.1.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Apr 4 22:31:43 UTC 2024 x86_64
User: cpt (1004)
PHP: 8.1.24
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/cpt/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;
  }
}