Refactor creating new list to Doctrine
[MAILPOET-3625]
This commit is contained in:
@ -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'),
|
||||||
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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();
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user