Add dynamic segments filter entity

[MAILPOET-3077]
This commit is contained in:
Rostislav Wolny
2020-09-15 17:00:12 +02:00
committed by Veljko V
parent 814686e8d2
commit d18d3b052d
9 changed files with 99 additions and 40 deletions

View File

@ -0,0 +1,68 @@
<?php
namespace MailPoet\Entities;
use MailPoet\Doctrine\EntityTraits\AutoincrementedIdTrait;
use MailPoet\Doctrine\EntityTraits\CreatedAtTrait;
use MailPoet\Doctrine\EntityTraits\SafeToOneAssociationLoadTrait;
use MailPoet\Doctrine\EntityTraits\UpdatedAtTrait;
use MailPoetVendor\Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Entity()
* @ORM\Table(name="dynamic_segment_filters")
*/
class DynamicSegmentFilterEntity {
use AutoincrementedIdTrait;
use CreatedAtTrait;
use UpdatedAtTrait;
use SafeToOneAssociationLoadTrait;
/**
* @ORM\ManyToOne(targetEntity="MailPoet\Entities\SegmentEntity", inversedBy="filters")
* @var SegmentEntity|null
*/
private $segment;
/**
* @ORM\Column(type="serialized_array")
* @var array|null
*/
private $filterData;
public function __construct(SegmentEntity $segment, array $filterData) {
$this->segment = $segment;
$this->filterData = $filterData;
}
/**
* @return SegmentEntity|null
*/
public function getSegment() {
$this->safelyLoadToOneAssociation('segment');
return $this->segment;
}
/**
* @return array|null
*/
public function getFilterData() {
return $this->filterData;
}
/**
* @return string|null
*/
public function getSegmentType() {
$filterData = $this->getFilterData();
return $filterData['segmentType'] ?? null;
}
public function setSegment(SegmentEntity $segment) {
$this->segment = $segment;
}
public function setFilterData(array $filterData) {
$this->filterData = $filterData;
}
}

View File

@ -6,6 +6,7 @@ use MailPoet\Doctrine\EntityTraits\AutoincrementedIdTrait;
use MailPoet\Doctrine\EntityTraits\CreatedAtTrait;
use MailPoet\Doctrine\EntityTraits\DeletedAtTrait;
use MailPoet\Doctrine\EntityTraits\UpdatedAtTrait;
use MailPoetVendor\Doctrine\Common\Collections\ArrayCollection;
use MailPoetVendor\Doctrine\ORM\Mapping as ORM;
use MailPoetVendor\Symfony\Component\Validator\Constraints as Assert;
@ -43,6 +44,19 @@ class SegmentEntity {
*/
private $description;
/**
* @ORM\OneToMany(targetEntity="MailPoet\Entities\DynamicSegmentFilterEntity", mappedBy="segment")
* @var DynamicSegmentFilterEntity[]|ArrayCollection
*/
private $dynamicFilters;
public function __construct(string $name, string $type, string $description = '') {
$this->name = $name;
$this->type = $type;
$this->description = $description;
$this->dynamicFilters = new ArrayCollection();
}
/**
* @return string
*/
@ -84,4 +98,11 @@ class SegmentEntity {
public function setDescription($description) {
$this->description = $description;
}
/**
* @return DynamicSegmentFilterEntity[]|ArrayCollection
*/
public function getDynamicFilters() {
return $this->dynamicFilters;
}
}

View File

@ -107,14 +107,8 @@ class SubscribersTest extends \MailPoetTest {
);
$this->obfuscatedEmail = $obfuscator->obfuscate('email');
$this->obfuscatedSegments = $obfuscator->obfuscate('segments');
$this->segment1 = new SegmentEntity();
$this->segment1->setName('Segment 1');
$this->segment1->setDescription('Segment 1');
$this->segment1->setType(SegmentEntity::TYPE_DEFAULT);
$this->segment2 = new SegmentEntity();
$this->segment2->setName('Segment 2');
$this->segment2->setDescription('Segment 2');
$this->segment2->setType(SegmentEntity::TYPE_DEFAULT);
$this->segment1 = new SegmentEntity('Segment 1', SegmentEntity::TYPE_DEFAULT, 'Segment 1');
$this->segment2 = new SegmentEntity('Segment 2', SegmentEntity::TYPE_DEFAULT, 'Segment 2');
$this->entityManager->persist($this->segment1);
$this->entityManager->persist($this->segment2);

View File

@ -59,10 +59,7 @@ class NewsletterEntityTest extends \MailPoetTest {
}
private function createSegment(): SegmentEntity {
$segment = new SegmentEntity();
$segment->setType(SegmentEntity::TYPE_DEFAULT);
$segment->setName('Segment');
$segment->setDescription('Segment description');
$segment = new SegmentEntity('Segment', SegmentEntity::TYPE_DEFAULT, 'Segment description');
$this->entityManager->persist($segment);
return $segment;
}

View File

@ -69,10 +69,7 @@ class NewsletterListingRepositoryTest extends \MailPoetTest {
$newsletter->setSubject('Newsletter without segment');
$this->entityManager->persist($newsletter);
$segment = new SegmentEntity();
$segment->setName('Segment');
$segment->setType(SegmentEntity::TYPE_DEFAULT);
$segment->setDescription('Segment description');
$segment = new SegmentEntity('Segment', SegmentEntity::TYPE_DEFAULT, 'Segment description');
$this->entityManager->persist($segment);
$newsletter = new NewsletterEntity();
@ -299,19 +296,13 @@ class NewsletterListingRepositoryTest extends \MailPoetTest {
$newsletter1->setSubject('Newsletter with segment 1');
$this->entityManager->persist($newsletter1);
$segment1 = new SegmentEntity();
$segment1->setName('Segment 1');
$segment1->setType(SegmentEntity::TYPE_DEFAULT);
$segment1->setDescription('Segment description');
$segment1 = new SegmentEntity('Segment 1', SegmentEntity::TYPE_DEFAULT, 'Segment description');
$this->entityManager->persist($segment1);
$newsletterSegment1 = new NewsletterSegmentEntity($newsletter1, $segment1);
$this->entityManager->persist($newsletterSegment1);
$segment2 = new SegmentEntity();
$segment2->setName('Segment 2');
$segment2->setType(SegmentEntity::TYPE_DEFAULT);
$segment2->setDescription('Segment without any newsletter');
$segment2 = new SegmentEntity('Segment 2', SegmentEntity::TYPE_DEFAULT, 'Segment without any newsletter');
$this->entityManager->persist($segment2);
$this->entityManager->flush();

View File

@ -259,10 +259,7 @@ class NewsletterRepositoryTest extends \MailPoetTest {
$this->entityManager->persist($queue);
$newsletter->getQueues()->add($queue);
$segment = new SegmentEntity();
$segment->setType(SegmentEntity::TYPE_DEFAULT);
$segment->setName(" List for newsletter id {$newsletter->getId()}");
$segment->setDescription('');
$segment = new SegmentEntity("List for newsletter id {$newsletter->getId()}", SegmentEntity::TYPE_DEFAULT);
$this->entityManager->persist($segment);
$subscriber = new SubscriberEntity();

View File

@ -170,10 +170,7 @@ class NewsletterSaveControllerTest extends \MailPoetTest {
}
public function testItCanModifySegmentsOfExistingNewsletter() {
$segment = new SegmentEntity();
$segment->setType(SegmentEntity::TYPE_DEFAULT);
$segment->setName('Segment 1');
$segment->setDescription('Segment 1 description');
$segment = new SegmentEntity('Segment 1', SegmentEntity::TYPE_DEFAULT, 'Segment 1 description');
$this->entityManager->persist($segment);
$this->entityManager->flush();
$fakeSegmentId = 1;

View File

@ -129,10 +129,7 @@ class SubscriberListingRepositoryTest extends \MailPoetTest {
}
private function createSegmentEntity(): SegmentEntity {
$segment = new SegmentEntity();
$segment->setName('Segment' . rand(0, 10000));
$segment->setType(SegmentEntity::TYPE_DEFAULT);
$segment->setDescription('Segment description');
$segment = new SegmentEntity('Segment' . rand(0, 10000), SegmentEntity::TYPE_DEFAULT, 'Segment description');
$this->entityManager->persist($segment);
return $segment;
}

View File

@ -48,10 +48,7 @@ class ManageSubscriptionFormRendererTest extends \MailPoetTest {
}
private function getSegment(): SegmentEntity {
$segment = new SegmentEntity();
$segment->setName('Test segment');
$segment->setDescription('Description');
$segment->setType(SegmentEntity::TYPE_DEFAULT);
$segment = new SegmentEntity('Test segment', SegmentEntity::TYPE_DEFAULT, 'Description');
$this->entityManager->persist($segment);
$this->entityManager->flush();
return $segment;