![]() 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/LeadBundle/EventListener/ |
<?php namespace Mautic\LeadBundle\EventListener; use Mautic\LeadBundle\Report\FieldsBuilder; use Mautic\ReportBundle\Event\ReportBuilderEvent; use Mautic\ReportBundle\Event\ReportGeneratorEvent; use Mautic\ReportBundle\ReportEvents; use Symfony\Component\EventDispatcher\EventSubscriberInterface; class SegmentReportSubscriber implements EventSubscriberInterface { public const SEGMENT_MEMBERSHIP = 'segment.membership'; public function __construct( private FieldsBuilder $fieldsBuilder ) { } public static function getSubscribedEvents(): array { return [ ReportEvents::REPORT_ON_BUILD => ['onReportBuilder', 0], ReportEvents::REPORT_ON_GENERATE => ['onReportGenerate', 0], ]; } /** * Add available tables and columns to the report builder lookup. */ public function onReportBuilder(ReportBuilderEvent $event): void { if (!$event->checkContext([self::SEGMENT_MEMBERSHIP])) { return; } $columns = $this->fieldsBuilder->getLeadFieldsColumns('l.'); $filters = $this->fieldsBuilder->getLeadFilter('l.', 'lll.'); $segmentColumns = [ 'lll.manually_removed' => [ 'label' => 'mautic.lead.report.segment.manually_removed', 'type' => 'bool', ], 'lll.manually_added' => [ 'label' => 'mautic.lead.report.segment.manually_added', 'type' => 'bool', ], ]; $data = [ 'display_name' => 'mautic.lead.report.segment.membership', 'columns' => array_merge($columns, $segmentColumns, $event->getStandardColumns('s.', ['publish_up', 'publish_down'])), 'filters' => $filters, ]; $event->addTable(self::SEGMENT_MEMBERSHIP, $data, ReportSubscriber::GROUP_CONTACTS); unset($columns, $filters, $segmentColumns, $data); } /** * Initialize the QueryBuilder object to generate reports from. */ public function onReportGenerate(ReportGeneratorEvent $event): void { if (!$event->checkContext([self::SEGMENT_MEMBERSHIP])) { return; } $qb = $event->getQueryBuilder(); $qb->from(MAUTIC_TABLE_PREFIX.'lead_lists_leads', 'lll') ->leftJoin('lll', MAUTIC_TABLE_PREFIX.'leads', 'l', 'l.id = lll.lead_id') ->leftJoin('lll', MAUTIC_TABLE_PREFIX.'lead_lists', 's', 's.id = lll.leadlist_id') ->andWhere('lll.manually_removed = 0'); if ($event->usesColumn(['u.first_name', 'u.last_name'])) { $qb->leftJoin('l', MAUTIC_TABLE_PREFIX.'users', 'u', 'u.id = l.owner_id'); } if ($event->usesColumn('i.ip_address')) { $event->addLeadIpAddressLeftJoin($qb); } $event->setQueryBuilder($qb); } }