Refactor creating new list to Doctrine

[MAILPOET-3625]
This commit is contained in:
Pavel Dohnal
2021-08-19 10:31:55 +02:00
committed by Veljko V
parent 3d1e2c5a2e
commit 3b7752daed
2 changed files with 28 additions and 12 deletions

View File

@ -2,15 +2,18 @@
namespace MailPoet\API\JSON\v1; namespace MailPoet\API\JSON\v1;
use InvalidArgumentException;
use MailPoet\API\JSON\Endpoint as APIEndpoint; use MailPoet\API\JSON\Endpoint as APIEndpoint;
use MailPoet\API\JSON\Error as APIError;
use MailPoet\API\JSON\ResponseBuilders\SegmentsResponseBuilder;
use MailPoet\Config\AccessControl; use MailPoet\Config\AccessControl;
use MailPoet\Cron\Workers\WooCommerceSync; use MailPoet\Cron\Workers\WooCommerceSync;
use MailPoet\CustomFields\CustomFieldsRepository; use MailPoet\CustomFields\CustomFieldsRepository;
use MailPoet\Doctrine\Validator\ValidationException;
use MailPoet\Entities\ScheduledTaskEntity; use MailPoet\Entities\ScheduledTaskEntity;
use MailPoet\Models\ScheduledTask;
use MailPoet\Models\Segment;
use MailPoet\Newsletter\Options\NewsletterOptionsRepository; use MailPoet\Newsletter\Options\NewsletterOptionsRepository;
use MailPoet\Newsletter\Sending\ScheduledTasksRepository; use MailPoet\Newsletter\Sending\ScheduledTasksRepository;
use MailPoet\Segments\SegmentSaveController;
use MailPoet\Segments\SegmentsRepository; use MailPoet\Segments\SegmentsRepository;
use MailPoet\Segments\WP; use MailPoet\Segments\WP;
use MailPoet\Subscribers\ImportExport\Export\Export; use MailPoet\Subscribers\ImportExport\Export\Export;
@ -43,6 +46,12 @@ class ImportExport extends APIEndpoint {
/** @var ScheduledTasksRepository */ /** @var ScheduledTasksRepository */
private $scheduledTasksRepository; private $scheduledTasksRepository;
/** @var SegmentSaveController */
private $segmentSavecontroller;
/** @var SegmentsResponseBuilder */
private $segmentsResponseBuilder;
public $permissions = [ public $permissions = [
'global' => AccessControl::PERMISSION_MANAGE_SUBSCRIBERS, 'global' => AccessControl::PERMISSION_MANAGE_SUBSCRIBERS,
]; ];
@ -54,6 +63,8 @@ class ImportExport extends APIEndpoint {
NewsletterOptionsRepository $newsletterOptionsRepository, NewsletterOptionsRepository $newsletterOptionsRepository,
SegmentsRepository $segmentsRepository, SegmentsRepository $segmentsRepository,
ScheduledTasksRepository $scheduledTasksRepository, ScheduledTasksRepository $scheduledTasksRepository,
SegmentSaveController $segmentSavecontroller,
SegmentsResponseBuilder $segmentsResponseBuilder,
SubscribersRepository $subscribersRepository SubscribersRepository $subscribersRepository
) { ) {
$this->wpSegment = $wpSegment; $this->wpSegment = $wpSegment;
@ -63,6 +74,8 @@ class ImportExport extends APIEndpoint {
$this->segmentsRepository = $segmentsRepository; $this->segmentsRepository = $segmentsRepository;
$this->subscriberRepository = $subscribersRepository; $this->subscriberRepository = $subscribersRepository;
$this->scheduledTasksRepository = $scheduledTasksRepository; $this->scheduledTasksRepository = $scheduledTasksRepository;
$this->segmentSavecontroller = $segmentSavecontroller;
$this->segmentsResponseBuilder = $segmentsResponseBuilder;
} }
public function getMailChimpLists($data) { public function getMailChimpLists($data) {
@ -90,15 +103,18 @@ class ImportExport extends APIEndpoint {
} }
public function addSegment($data) { public function addSegment($data) {
$segment = Segment::createOrUpdate($data); try {
$errors = $segment->getErrors(); $segment = $this->segmentSavecontroller->save($data);
$response = $this->segmentsResponseBuilder->build($segment);
if (!empty($errors)) { return $this->successResponse($response);
return $this->errorResponse($errors); } catch (ValidationException $exception) {
} else { return $this->badRequest([
$segment = Segment::findOne($segment->id); APIError::BAD_REQUEST => __('Please specify a name.', 'mailpoet'),
if(!$segment instanceof Segment) return $this->errorResponse(); ]);
return $this->successResponse($segment->asArray()); } catch (InvalidArgumentException $exception) {
return $this->badRequest([
APIError::BAD_REQUEST => __('Another record already exists. Please specify a different "name".', 'mailpoet'),
]);
} }
} }

View File

@ -25,7 +25,7 @@ class ImportExportTest extends \MailPoetTest {
$this->entityManager->createQueryBuilder() $this->entityManager->createQueryBuilder()
->delete(ScheduledTaskEntity::class, 's') ->delete(ScheduledTaskEntity::class, 's')
->where('s.type = :type') ->where('s.type = :type')
->setParameter(':type',WooCommerceSync::TASK_TYPE ) ->setParameter(':type', WooCommerceSync::TASK_TYPE )
->getQuery() ->getQuery()
->execute(); ->execute();
} }