Add saving custom fields on subscribe
[MAILPOET-3032]
This commit is contained in:
@ -82,6 +82,9 @@ class SubscriberActions {
|
|||||||
$subscriber->setUnconfirmedData($unconfirmedData ?: null);
|
$subscriber->setUnconfirmedData($unconfirmedData ?: null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Update custom fields
|
||||||
|
$this->subscriberSaveController->updateCustomFields($subscriberData, $subscriber);
|
||||||
|
|
||||||
// restore trashed subscriber
|
// restore trashed subscriber
|
||||||
if ($subscriber->getDeletedAt()) {
|
if ($subscriber->getDeletedAt()) {
|
||||||
$subscriber->setDeletedAt(null);
|
$subscriber->setDeletedAt(null);
|
||||||
|
@ -229,7 +229,7 @@ class SubscriberSaveController {
|
|||||||
return $subscriber;
|
return $subscriber;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function updateCustomFields(array $data, SubscriberEntity $subscriber): void {
|
public function updateCustomFields(array $data, SubscriberEntity $subscriber): void {
|
||||||
$customFieldsMap = [];
|
$customFieldsMap = [];
|
||||||
foreach ($data as $key => $value) {
|
foreach ($data as $key => $value) {
|
||||||
if (strpos($key, 'cf_') === 0) {
|
if (strpos($key, 'cf_') === 0) {
|
||||||
|
@ -3,8 +3,10 @@
|
|||||||
namespace MailPoet\Subscribers;
|
namespace MailPoet\Subscribers;
|
||||||
|
|
||||||
use Codeception\Util\Fixtures;
|
use Codeception\Util\Fixtures;
|
||||||
|
use MailPoet\Entities\CustomFieldEntity;
|
||||||
use MailPoet\Entities\FormEntity;
|
use MailPoet\Entities\FormEntity;
|
||||||
use MailPoet\Entities\SegmentEntity;
|
use MailPoet\Entities\SegmentEntity;
|
||||||
|
use MailPoet\Entities\SubscriberCustomFieldEntity;
|
||||||
use MailPoet\Entities\SubscriberEntity;
|
use MailPoet\Entities\SubscriberEntity;
|
||||||
use MailPoet\Entities\SubscriberSegmentEntity;
|
use MailPoet\Entities\SubscriberSegmentEntity;
|
||||||
use MailPoet\Form\Util\FieldNameObfuscator;
|
use MailPoet\Form\Util\FieldNameObfuscator;
|
||||||
@ -33,6 +35,9 @@ class SubscriberSubscribeControllerTest extends \MailPoetTest {
|
|||||||
/** @var string */
|
/** @var string */
|
||||||
private $obfuscatedSegments;
|
private $obfuscatedSegments;
|
||||||
|
|
||||||
|
/** @var SubscriberCustomFieldRepository */
|
||||||
|
private $subscriberCustomFieldRepository;
|
||||||
|
|
||||||
public function _before() {
|
public function _before() {
|
||||||
parent::_before();
|
parent::_before();
|
||||||
$this->cleanup();
|
$this->cleanup();
|
||||||
@ -44,6 +49,7 @@ class SubscriberSubscribeControllerTest extends \MailPoetTest {
|
|||||||
$this->subscribersRepository = $this->diContainer->get(SubscribersRepository::class);
|
$this->subscribersRepository = $this->diContainer->get(SubscribersRepository::class);
|
||||||
$this->segmentsRepository = $this->diContainer->get(SegmentsRepository::class);
|
$this->segmentsRepository = $this->diContainer->get(SegmentsRepository::class);
|
||||||
$this->subscribersRepository = $this->diContainer->get(SubscribersRepository::class);
|
$this->subscribersRepository = $this->diContainer->get(SubscribersRepository::class);
|
||||||
|
$this->subscriberCustomFieldRepository = $this->diContainer->get(SubscriberCustomFieldRepository::class);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testItCanSubscribeSubscriberWithoutConfirmation(): void {
|
public function testItCanSubscribeSubscriberWithoutConfirmation(): void {
|
||||||
@ -82,11 +88,42 @@ class SubscriberSubscribeControllerTest extends \MailPoetTest {
|
|||||||
expect($subscriber->getStatus())->equals(SubscriberEntity::STATUS_UNCONFIRMED);
|
expect($subscriber->getStatus())->equals(SubscriberEntity::STATUS_UNCONFIRMED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function testItCanSubscribeSubscriberWithCustomField(): void {
|
||||||
|
$this->settings->set('signup_confirmation.enabled', false);
|
||||||
|
$segment = $this->segmentsRepository->createOrUpdate('Segment 1');
|
||||||
|
$customField = $this->createCustomField('Custom Field');
|
||||||
|
$form = $this->createForm($segment, [$customField]);
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
$this->obfuscatedEmail => 'subscriber' . rand(0, 10000) . '@example.com',
|
||||||
|
$this->obfuscatedSegments => [$segment->getId()],
|
||||||
|
'form_id' => $form->getId(),
|
||||||
|
'cf_' . $customField->getId() => 'field value',
|
||||||
|
];
|
||||||
|
$this->subscribeController->subscribe($data);
|
||||||
|
|
||||||
|
$subscriber = $this->subscribersRepository->findOneBy(['email' => $data[$this->obfuscatedEmail]]);
|
||||||
|
assert($subscriber instanceof SubscriberEntity);
|
||||||
|
expect($subscriber)->isInstanceOf(SubscriberEntity::class);
|
||||||
|
expect($subscriber->getStatus())->equals(SubscriberEntity::STATUS_SUBSCRIBED);
|
||||||
|
$subscriberCustomFields = $this->subscriberCustomFieldRepository->findBy(['subscriber' => $subscriber]);
|
||||||
|
expect($subscriberCustomFields)->count(1);
|
||||||
|
$subscriberCustomField = reset($subscriberCustomFields);
|
||||||
|
assert($subscriberCustomField instanceof SubscriberCustomFieldEntity);
|
||||||
|
expect($subscriberCustomField)->isInstanceOf(SubscriberCustomFieldEntity::class);
|
||||||
|
expect($subscriberCustomField->getSubscriber())->equals($subscriber);
|
||||||
|
expect($subscriberCustomField->getCustomField())->equals($customField);
|
||||||
|
expect($subscriberCustomField->getValue())->equals($data['cf_' . $customField->getId()]);
|
||||||
|
}
|
||||||
|
|
||||||
public function _after(): void {
|
public function _after(): void {
|
||||||
$this->cleanup();
|
$this->cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
private function createForm(SegmentEntity $segment): FormEntity {
|
/**
|
||||||
|
* @param CustomFieldEntity[] $customFields
|
||||||
|
*/
|
||||||
|
private function createForm(SegmentEntity $segment, array $customFields = []): FormEntity {
|
||||||
$form = new FormEntity('Form' . rand(0, 10000));
|
$form = new FormEntity('Form' . rand(0, 10000));
|
||||||
$body = Fixtures::get('form_body_template');
|
$body = Fixtures::get('form_body_template');
|
||||||
// Add segment selection block
|
// Add segment selection block
|
||||||
@ -96,6 +133,14 @@ class SubscriberSubscribeControllerTest extends \MailPoetTest {
|
|||||||
'values' => [['id' => $segment->getId()]],
|
'values' => [['id' => $segment->getId()]],
|
||||||
],
|
],
|
||||||
];
|
];
|
||||||
|
foreach ($customFields as $customField) {
|
||||||
|
$body[] = [
|
||||||
|
'type' => $customField->getType(),
|
||||||
|
'name' => $customField->getName(),
|
||||||
|
'id' => $customField->getId(),
|
||||||
|
'params' => $customField->getParams(),
|
||||||
|
];
|
||||||
|
}
|
||||||
$form->setBody($body);
|
$form->setBody($body);
|
||||||
$form->setSettings([
|
$form->setSettings([
|
||||||
'segments_selected_by' => 'user',
|
'segments_selected_by' => 'user',
|
||||||
@ -106,6 +151,15 @@ class SubscriberSubscribeControllerTest extends \MailPoetTest {
|
|||||||
return $form;
|
return $form;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function createCustomField(string $name): CustomFieldEntity {
|
||||||
|
$customField = new CustomFieldEntity();
|
||||||
|
$customField->setType(CustomFieldEntity::TYPE_TEXT);
|
||||||
|
$customField->setName($name);
|
||||||
|
$this->entityManager->persist($customField);
|
||||||
|
$this->entityManager->flush();
|
||||||
|
return $customField;
|
||||||
|
}
|
||||||
|
|
||||||
private function cleanup(): void {
|
private function cleanup(): void {
|
||||||
$this->truncateEntity(FormEntity::class);
|
$this->truncateEntity(FormEntity::class);
|
||||||
$this->truncateEntity(SubscriberEntity::class);
|
$this->truncateEntity(SubscriberEntity::class);
|
||||||
|
Reference in New Issue
Block a user