Server IP : 104.21.14.103 / Your IP : 18.227.209.207 Web Server : LiteSpeed System : Linux business53.web-hosting.com 4.18.0-553.lve.el8.x86_64 #1 SMP Mon May 27 15:27:34 UTC 2024 x86_64 User : giankuin ( 1871) PHP Version : 7.4.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/self/root/proc/thread-self/root/proc/thread-self/root/home/giankuin/thietke365.net/wp-content/plugins/mailpoet/lib/Segments/ |
Upload File : |
<?php // phpcs:ignore SlevomatCodingStandard.TypeHints.DeclareStrictTypes.DeclareStrictTypesMissing namespace MailPoet\Segments; if (!defined('ABSPATH')) exit; use MailPoet\ConflictException; use MailPoet\Entities\SegmentEntity; use MailPoet\Entities\SubscriberSegmentEntity; use MailPoet\NotFoundException; use MailPoetVendor\Doctrine\ORM\EntityManager; use MailPoetVendor\Doctrine\ORM\ORMException; class SegmentSaveController { /** @var SegmentsRepository */ private $segmentsRepository; /** @var EntityManager */ private $entityManager; public function __construct( SegmentsRepository $segmentsRepository, EntityManager $entityManager ) { $this->segmentsRepository = $segmentsRepository; $this->entityManager = $entityManager; } /** * @throws ConflictException * @throws NotFoundException * @throws ORMException */ public function save(array $data = []): SegmentEntity { $id = isset($data['id']) ? (int)$data['id'] : null; $name = $data['name'] ?? ''; $description = $data['description'] ?? ''; $displayInManageSubPage = isset($data['showInManageSubscriptionPage']) ? (int)$data['showInManageSubscriptionPage'] : false; return $this->segmentsRepository->createOrUpdate($name, $description, SegmentEntity::TYPE_DEFAULT, [], $id, (bool)$displayInManageSubPage); } /** * @throws ConflictException */ public function duplicate(SegmentEntity $segmentEntity): SegmentEntity { $duplicate = clone $segmentEntity; // translators: %s is the name of the segment $duplicate->setName(sprintf(__('Copy of %s', 'mailpoet'), $segmentEntity->getName())); $this->segmentsRepository->verifyNameIsUnique($duplicate->getName(), $duplicate->getId()); $this->entityManager->transactional(function (EntityManager $entityManager) use ($duplicate, $segmentEntity) { $entityManager->persist($duplicate); $entityManager->flush(); $subscriberSegmentTable = $entityManager->getClassMetadata(SubscriberSegmentEntity::class)->getTableName(); $conn = $this->entityManager->getConnection(); $stmt = $conn->prepare(" INSERT INTO $subscriberSegmentTable (segment_id, subscriber_id, status, created_at) SELECT :duplicateId, subscriber_id, status, NOW() FROM $subscriberSegmentTable WHERE segment_id = :segmentId "); $stmt->executeQuery([ 'duplicateId' => $duplicate->getId(), 'segmentId' => $segmentEntity->getId(), ]); }); return $duplicate; } }