![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/app/bundles/EmailBundle/Stats/Helper/ |
<?php namespace Mautic\EmailBundle\Stats\Helper; use Mautic\EmailBundle\Stats\FetchOptions\EmailStatOptions; use Mautic\StatsBundle\Aggregate\Collection\StatCollection; class ClickedHelper extends AbstractHelper { public const NAME = 'email-clicked'; public function getName(): string { return self::NAME; } /** * @throws \Exception */ public function generateStats(\DateTime $fromDateTime, \DateTime $toDateTime, EmailStatOptions $options, StatCollection $statCollection): void { $query = $this->getQuery($fromDateTime, $toDateTime); $q = $query->prepareTimeDataQuery('page_hits', 'date_hit', []); if ($segmentId = $options->getSegmentId()) { $q->innerJoin( 't', '(SELECT DISTINCT email_id, lead_id FROM '.MAUTIC_TABLE_PREFIX.'email_stats WHERE list_id = :segmentId)', 'es', 't.source_id = es.email_id' ); $q->setParameter('segmentId', $segmentId); } $q->andWhere('t.source = :source'); $q->setParameter('source', 'email'); $this->limitQueryToEmailIds($q, $options->getEmailIds(), 'source_id', 't'); if (!$options->canViewOthers()) { $this->limitQueryToCreator($q); } $this->addCompanyFilter($q, $options->getCompanyId()); $this->addCampaignFilterForEmailSource($q, $options->getCampaignId()); $this->addSegmentFilter($q, $segmentId, 'es'); $this->fetchAndBindToCollection($q, $statCollection); } }