AccessControl::PERMISSION_MANAGE_FORMS, ]; /** @var Listing\BulkActionController */ private $bulkAction; /** @var Listing\Handler */ private $listingHandler; /** @var UserFlagsController */ private $userFlags; /** @var FormFactory */ private $formFactory; /** @var FormsResponseBuilder */ private $formsResponseBuilder; /** @var WPFunctions */ private $wp; /** @var FormsRepository */ private $formsRepository; /** @var Emoji */ private $emoji; public function __construct( Listing\BulkActionController $bulkAction, Listing\Handler $listingHandler, UserFlagsController $userFlags, FormFactory $formFactory, FormsRepository $formsRepository, FormsResponseBuilder $formsResponseBuilder, WPFunctions $wp, Emoji $emoji ) { $this->bulkAction = $bulkAction; $this->listingHandler = $listingHandler; $this->userFlags = $userFlags; $this->formFactory = $formFactory; $this->wp = $wp; $this->formsRepository = $formsRepository; $this->formsResponseBuilder = $formsResponseBuilder; $this->emoji = $emoji; } public function get($data = []) { $id = (isset($data['id']) ? (int)$data['id'] : false); $form = $this->formsRepository->findOneById($id); if ($form instanceof FormEntity) { return $this->successResponse($this->formsResponseBuilder->build($form)); } return $this->errorResponse([ APIError::NOT_FOUND => WPFunctions::get()->__('This form does not exist.', 'mailpoet'), ]); } public function setStatus($data = []) { $status = (isset($data['status']) ? $data['status'] : null); if (!$status) { return $this->badRequest([ APIError::BAD_REQUEST => __('You need to specify a status.', 'mailpoet'), ]); } $id = (isset($data['id'])) ? (int)$data['id'] : false; $form = $this->formsRepository->findOneById($id); if (!$form instanceof FormEntity) { return $this->errorResponse([ APIError::NOT_FOUND => __('This form does not exist.', 'mailpoet'), ]); } if (!in_array($status, [FormEntity::STATUS_ENABLED, FormEntity::STATUS_DISABLED])) { return $this->badRequest([ APIError::BAD_REQUEST => sprintf( __('Invalid status. Allowed values are (%1$s), you specified %2$s', 'mailpoet'), join(', ', [FormEntity::STATUS_ENABLED, FormEntity::STATUS_DISABLED]), $status ), ]); } $form->setStatus($status); $this->formsRepository->flush(); $form = $this->formsRepository->findOneById($id); if (!$form instanceof FormEntity) return $this->errorResponse(); return $this->successResponse( $form->toArray() ); } public function listing($data = []) { $data['sort_order'] = $data['sort_order'] ?? 'desc'; $data['sort_by'] = $data['sort_by'] ?? 'updated_at'; $listingData = $this->listingHandler->get('\MailPoet\Models\Form', $data); $data = []; foreach ($listingData['items'] as $form) { $form = $form->asArray(); $form['signups'] = StatisticsForms::getTotalSignups($form['id']); $form['segments'] = ( !empty($form['settings']['segments']) ? $form['settings']['segments'] : [] ); $data[] = $form; } return $this->successResponse($data, [ 'count' => $listingData['count'], 'filters' => $listingData['filters'], 'groups' => $listingData['groups'], ]); } public function create($data = []) { if (isset($data['template-id'])) { $formEntity = $this->formFactory->createFormFromTemplate($data['template-id']); } else { $formEntity = $this->formFactory->createEmptyForm(); } $form = Form::findOne($formEntity->getId()); if(!$form instanceof Form) return $this->errorResponse(); return $this->successResponse($form->asArray()); } public function previewEditor($data = []) { $formId = $data['id'] ?? null; if (!$formId) { $this->badRequest(); } $this->wp->setTransient(PreviewPage::PREVIEW_DATA_TRANSIENT_PREFIX . $formId, $data, PreviewPage::PREVIEW_DATA_EXPIRATION); return $this->successResponse(); } public function exportsEditor($data = []) { $id = (isset($data['id']) ? (int)$data['id'] : false); $form = Form::findOne($id); if ($form instanceof Form) { $exports = Util\Export::getAll($form->asArray()); return $this->successResponse($exports); } return $this->errorResponse([ APIError::NOT_FOUND => WPFunctions::get()->__('This form does not exist.', 'mailpoet'), ]); } public function saveEditor($data = []) { $formId = (isset($data['id']) ? (int)$data['id'] : 0); $name = (isset($data['name']) ? $data['name'] : WPFunctions::get()->__('New form', 'mailpoet')); $body = (isset($data['body']) ? $data['body'] : []); $settings = (isset($data['settings']) ? $data['settings'] : []); $styles = (isset($data['styles']) ? $data['styles'] : ''); $status = (isset($data['status']) ? $data['status'] : FormEntity::STATUS_ENABLED); // check if the form is used as a widget $isWidget = false; $widgets = WPFunctions::get()->getOption('widget_mailpoet_form'); if (!empty($widgets)) { foreach ($widgets as $widget) { if (isset($widget['form']) && (int)$widget['form'] === $formId) { $isWidget = true; break; } } } WPFunctions::get()->deleteTransient(DisplayFormInWPContent::NO_FORM_TRANSIENT_KEY); // check if the user gets to pick his own lists // or if it's selected by the admin $hasSegmentSelection = false; $listSelection = []; foreach ($body as $i => $block) { if ($block['type'] === 'segment') { $hasSegmentSelection = true; if (!empty($block['params']['values'])) { $listSelection = array_filter( array_map(function($segment) { return (isset($segment['id']) ? $segment['id'] : null ); }, $block['params']['values']) ); } break; } } // check list selection if ($hasSegmentSelection === true) { $settings['segments_selected_by'] = 'user'; $settings['segments'] = $listSelection; } else { $settings['segments_selected_by'] = 'admin'; } if ($body !== null) { $body = $this->emoji->sanitizeEmojisInFormBody($body); } $form = Form::createOrUpdate([ 'id' => $formId, 'name' => $name, 'body' => $body, 'settings' => $settings, 'styles' => $styles, 'status' => $status, ]); $errors = $form->getErrors(); if (!empty($errors)) { return $this->badRequest($errors); } if (isset($data['editor_version']) && $data['editor_version'] === "2") { $this->userFlags->set('display_new_form_editor_nps_survey', true); } $form = Form::findOne($form->id); if(!$form instanceof Form) return $this->errorResponse(); return $this->successResponse( $form->asArray(), ['is_widget' => $isWidget] ); } public function restore($data = []) { $id = (isset($data['id']) ? (int)$data['id'] : false); $form = Form::findOne($id); if ($form instanceof Form) { $form->restore(); $form = Form::findOne($form->id); if(!$form instanceof Form) return $this->errorResponse(); return $this->successResponse( $form->asArray(), ['count' => 1] ); } else { return $this->errorResponse([ APIError::NOT_FOUND => WPFunctions::get()->__('This form does not exist.', 'mailpoet'), ]); } } public function trash($data = []) { $id = (isset($data['id']) ? (int)$data['id'] : false); $form = Form::findOne($id); if ($form instanceof Form) { $form->trash(); $form = Form::findOne($form->id); if(!$form instanceof Form) return $this->errorResponse(); return $this->successResponse( $form->asArray(), ['count' => 1] ); } else { return $this->errorResponse([ APIError::NOT_FOUND => WPFunctions::get()->__('This form does not exist.', 'mailpoet'), ]); } } public function delete($data = []) { $id = (isset($data['id']) ? (int)$data['id'] : false); $form = Form::findOne($id); if ($form instanceof Form) { $form->delete(); return $this->successResponse(null, ['count' => 1]); } else { return $this->errorResponse([ APIError::NOT_FOUND => WPFunctions::get()->__('This form does not exist.', 'mailpoet'), ]); } } public function duplicate($data = []) { $id = (isset($data['id']) ? (int)$data['id'] : false); $form = Form::findOne($id); if ($form instanceof Form) { $formName = $form->name ? sprintf(__('Copy of %s', 'mailpoet'), $form->name) : ''; $data = [ 'name' => $formName, ]; $duplicate = $form->duplicate($data); $errors = $duplicate->getErrors(); if (!empty($errors)) { return $this->errorResponse($errors); } else { $duplicate = Form::findOne($duplicate->id); if(!$duplicate instanceof Form) return $this->errorResponse(); return $this->successResponse( $duplicate->asArray(), ['count' => 1] ); } } else { return $this->errorResponse([ APIError::NOT_FOUND => WPFunctions::get()->__('This form does not exist.', 'mailpoet'), ]); } } public function bulkAction($data = []) { try { $meta = $this->bulkAction->apply('\MailPoet\Models\Form', $data); return $this->successResponse(null, $meta); } catch (\Exception $e) { return $this->errorResponse([ $e->getCode() => $e->getMessage(), ]); } } }