Extract workflow step updating to a separate controller
[MAILPOET-4515]
This commit is contained in:
@ -0,0 +1,28 @@
|
|||||||
|
<?php declare(strict_types = 1);
|
||||||
|
|
||||||
|
namespace MailPoet\Automation\Engine\Builder;
|
||||||
|
|
||||||
|
use MailPoet\Automation\Engine\Workflows\Step;
|
||||||
|
use MailPoet\Automation\Engine\Workflows\Workflow;
|
||||||
|
|
||||||
|
class UpdateStepsController {
|
||||||
|
public function updateSteps(Workflow $workflow, array $data): Workflow {
|
||||||
|
$steps = [];
|
||||||
|
foreach ($data as $stepData) {
|
||||||
|
$step = $this->processStep($stepData);
|
||||||
|
$steps[$step->getId()] = $step;
|
||||||
|
}
|
||||||
|
$workflow->setSteps($steps);
|
||||||
|
return $workflow;
|
||||||
|
}
|
||||||
|
|
||||||
|
private function processStep(array $data): Step {
|
||||||
|
return new Step(
|
||||||
|
$data['id'],
|
||||||
|
$data['type'],
|
||||||
|
$data['key'],
|
||||||
|
$data['next_step_id'] ?? null,
|
||||||
|
$data['args'] ?? null
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
@ -5,17 +5,21 @@ namespace MailPoet\Automation\Engine\Builder;
|
|||||||
use MailPoet\Automation\Engine\Exceptions;
|
use MailPoet\Automation\Engine\Exceptions;
|
||||||
use MailPoet\Automation\Engine\Exceptions\UnexpectedValueException;
|
use MailPoet\Automation\Engine\Exceptions\UnexpectedValueException;
|
||||||
use MailPoet\Automation\Engine\Storage\WorkflowStorage;
|
use MailPoet\Automation\Engine\Storage\WorkflowStorage;
|
||||||
use MailPoet\Automation\Engine\Workflows\Step;
|
|
||||||
use MailPoet\Automation\Engine\Workflows\Workflow;
|
use MailPoet\Automation\Engine\Workflows\Workflow;
|
||||||
|
|
||||||
class UpdateWorkflowController {
|
class UpdateWorkflowController {
|
||||||
/** @var WorkflowStorage */
|
/** @var WorkflowStorage */
|
||||||
private $storage;
|
private $storage;
|
||||||
|
|
||||||
|
/** @var UpdateStepsController */
|
||||||
|
private $updateStepsController;
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
WorkflowStorage $storage
|
WorkflowStorage $storage,
|
||||||
|
UpdateStepsController $updateStepsController
|
||||||
) {
|
) {
|
||||||
$this->storage = $storage;
|
$this->storage = $storage;
|
||||||
|
$this->updateStepsController = $updateStepsController;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function updateWorkflow(int $id, array $data): Workflow {
|
public function updateWorkflow(int $id, array $data): Workflow {
|
||||||
@ -43,17 +47,7 @@ class UpdateWorkflowController {
|
|||||||
|
|
||||||
if (array_key_exists('steps', $data)) {
|
if (array_key_exists('steps', $data)) {
|
||||||
$this->validateWorkflowSteps($workflow, $data['steps']);
|
$this->validateWorkflowSteps($workflow, $data['steps']);
|
||||||
$steps = [];
|
$this->updateStepsController->updateSteps($workflow, $data['steps']);
|
||||||
foreach ($data['steps'] as $step) {
|
|
||||||
$steps[(string)$step['id']] = new Step(
|
|
||||||
$step['id'],
|
|
||||||
$step['type'],
|
|
||||||
$step['key'],
|
|
||||||
$step['next_step_id'] ?? null,
|
|
||||||
$step['args'] ?? null
|
|
||||||
);
|
|
||||||
}
|
|
||||||
$workflow->setSteps($steps);
|
|
||||||
$changed = true;
|
$changed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -111,6 +111,7 @@ class ContainerConfigurator implements IContainerConfigurator {
|
|||||||
->setPublic(true)
|
->setPublic(true)
|
||||||
->setArgument('$container', new Reference(ContainerWrapper::class));
|
->setArgument('$container', new Reference(ContainerWrapper::class));
|
||||||
$container->autowire(\MailPoet\Automation\Engine\Builder\CreateWorkflowFromTemplateController::class)->setPublic(true);
|
$container->autowire(\MailPoet\Automation\Engine\Builder\CreateWorkflowFromTemplateController::class)->setPublic(true);
|
||||||
|
$container->autowire(\MailPoet\Automation\Engine\Builder\UpdateStepsController::class)->setPublic(true);
|
||||||
$container->autowire(\MailPoet\Automation\Engine\Builder\UpdateWorkflowController::class)->setPublic(true);
|
$container->autowire(\MailPoet\Automation\Engine\Builder\UpdateWorkflowController::class)->setPublic(true);
|
||||||
$container->autowire(\MailPoet\Automation\Engine\Control\ActionScheduler::class)->setPublic(true);
|
$container->autowire(\MailPoet\Automation\Engine\Control\ActionScheduler::class)->setPublic(true);
|
||||||
$container->autowire(\MailPoet\Automation\Engine\Control\StepRunner::class)->setPublic(true);
|
$container->autowire(\MailPoet\Automation\Engine\Control\StepRunner::class)->setPublic(true);
|
||||||
|
Reference in New Issue
Block a user