From 51b0fab83828f4dcb9903a60884ea1900675c1dd Mon Sep 17 00:00:00 2001 From: sebprt Date: Tue, 14 Nov 2023 17:23:27 +0100 Subject: [PATCH 1/2] Improved the Pipeline builder to add a stepCode on each method of the runtime + made the step code required in the configuration --- src/Builder/Pipeline.php | 6 +++++ src/Pipeline/Extractor.php | 1 + src/Pipeline/Loader.php | 1 + src/Pipeline/Transformer.php | 1 + src/Runtime/Pipeline/Configuration.php | 24 ++++++++++++------- src/Runtime/Workflow/Action/Configuration.php | 9 ++++++- src/Service.php | 4 ++-- 7 files changed, 34 insertions(+), 12 deletions(-) diff --git a/src/Builder/Pipeline.php b/src/Builder/Pipeline.php index 80aa8c8c..12d38a2a 100644 --- a/src/Builder/Pipeline.php +++ b/src/Builder/Pipeline.php @@ -16,6 +16,7 @@ public function __construct( ) {} public function addExtractor( + Node\Expr|Builder $stepCode, Node\Expr|Builder $extractor, Node\Expr|Builder $rejection, Node\Expr|Builder $state, @@ -24,6 +25,7 @@ public function addExtractor( var: $runtime, name: new Node\Identifier('extract'), args: [ + new Node\Arg($stepCode instanceof Builder ? $stepCode->getNode() : $stepCode), new Node\Arg($extractor instanceof Builder ? $extractor->getNode() : $extractor), new Node\Arg($rejection instanceof Builder ? $rejection->getNode() : $rejection), new Node\Arg($state instanceof Builder ? $state->getNode() : $state), @@ -34,6 +36,7 @@ public function addExtractor( } public function addTransformer( + Node\Expr|Builder $stepCode, Node\Expr|Builder $transformer, Node\Expr|Builder $rejection, Node\Expr|Builder $state, @@ -42,6 +45,7 @@ public function addTransformer( var: $runtime, name: new Node\Identifier('transform'), args: [ + new Node\Arg($stepCode instanceof Builder ? $stepCode->getNode() : $stepCode), new Node\Arg($transformer instanceof Builder ? $transformer->getNode() : $transformer), new Node\Arg($rejection instanceof Builder ? $rejection->getNode() : $rejection), new Node\Arg($state instanceof Builder ? $state->getNode() : $state), @@ -52,6 +56,7 @@ public function addTransformer( } public function addLoader( + Node\Expr|Builder $stepCode, Node\Expr|Builder $loader, Node\Expr|Builder $rejection, Node\Expr|Builder $state, @@ -60,6 +65,7 @@ public function addLoader( var: $runtime, name: new Node\Identifier('load'), args: [ + new Node\Arg($stepCode instanceof Builder ? $stepCode->getNode() : $stepCode), new Node\Arg($loader instanceof Builder ? $loader->getNode() : $loader), new Node\Arg($rejection instanceof Builder ? $rejection->getNode() : $rejection), new Node\Arg($state instanceof Builder ? $state->getNode() : $state), diff --git a/src/Pipeline/Extractor.php b/src/Pipeline/Extractor.php index c362d0bf..1e2ecc75 100644 --- a/src/Pipeline/Extractor.php +++ b/src/Pipeline/Extractor.php @@ -62,6 +62,7 @@ public function __invoke(array $config, Pipeline $pipeline, StepRepositoryInterf } $pipeline->addExtractor( + new Node\Scalar\String_($config['code']), $repository->getBuilder() ->withLogger($logger) ->withRejection($rejection) diff --git a/src/Pipeline/Loader.php b/src/Pipeline/Loader.php index 7f8748d6..0910ee24 100644 --- a/src/Pipeline/Loader.php +++ b/src/Pipeline/Loader.php @@ -62,6 +62,7 @@ public function __invoke(array $config, Pipeline $pipeline, StepRepositoryInterf } $pipeline->addLoader( + new Node\Scalar\String_($config['code']), $repository->getBuilder() ->withLogger($logger) ->withRejection($rejection) diff --git a/src/Pipeline/Transformer.php b/src/Pipeline/Transformer.php index f710cf6c..0a9396d7 100644 --- a/src/Pipeline/Transformer.php +++ b/src/Pipeline/Transformer.php @@ -62,6 +62,7 @@ public function __invoke(array $config, Pipeline $pipeline, StepRepositoryInterf } $pipeline->addTransformer( + new Node\Scalar\String_($config['code']), $repository->getBuilder() ->withLogger($logger) ->withRejection($rejection) diff --git a/src/Runtime/Pipeline/Configuration.php b/src/Runtime/Pipeline/Configuration.php index a3086eeb..efb317fd 100644 --- a/src/Runtime/Pipeline/Configuration.php +++ b/src/Runtime/Pipeline/Configuration.php @@ -49,12 +49,12 @@ public function getStepsTreeBuilder(): TreeBuilder ->isRequired() ->fixXmlConfig('step') ->validate() - ->ifTrue(fn ($value) => 1 <= array_reduce( - array_keys($this->plugins), - fn (int $count, string $plugin) => \array_key_exists($plugin, $value) ? $count + 1 : $count, - 0 - )) - ->thenInvalid(sprintf('You should only specify one plugin between %s.', implode('", "', array_map(fn (string $plugin) => sprintf('"%s"', $plugin), array_keys($this->plugins))))) + ->ifTrue(fn ($value) => 1 <= array_reduce( + array_keys($this->plugins), + fn (int $count, string $plugin) => \array_key_exists($plugin, $value) ? $count + 1 : $count, + 0 + )) + ->thenInvalid(sprintf('You should only specify one plugin between %s.', implode('", "', array_map(fn (string $plugin) => sprintf('"%s"', $plugin), array_keys($this->plugins))))) ->end() ; @@ -80,7 +80,9 @@ public function getConfigTreeBuilder(): TreeBuilder ->scalarPrototype()->end() ->end() ->scalarNode('name')->end() - ->scalarNode('code')->end() + ->scalarNode('code') + ->isRequired() + ->end() ->append($this->getStepsTreeBuilder()->getRootNode()) ->end() ; @@ -95,7 +97,9 @@ private function applyPlugins(ArrayNodeDefinition $node): self $node ->children() ->scalarNode('name')->end() - ->scalarNode('code')->end() + ->scalarNode('code') + ->isRequired() + ->end() ->end() ->append($plugin->getConfigTreeBuilder()->getRootNode()) ; @@ -110,7 +114,9 @@ private function applyFeatures(ArrayNodeDefinition $node): self /* @phpstan-ignore-next-line */ $node->children() ->scalarNode('name')->end() - ->scalarNode('code')->end() + ->scalarNode('code') + ->isRequired() + ->end() ->end() ->append($feature->getConfigTreeBuilder()->getRootNode()) ; diff --git a/src/Runtime/Workflow/Action/Configuration.php b/src/Runtime/Workflow/Action/Configuration.php index 0b11a899..4d5602e7 100644 --- a/src/Runtime/Workflow/Action/Configuration.php +++ b/src/Runtime/Workflow/Action/Configuration.php @@ -26,7 +26,14 @@ public function getConfigTreeBuilder(): TreeBuilder $builder = new TreeBuilder('action'); /** @var ArrayNodeDefinition $node */ - $node = $builder->getRootNode(); + $node = $builder->getRootNode() + ->children() + ->scalarNode('name')->end() + ->scalarNode('code') + ->isRequired() + ->end() + ->end() + ; foreach ($this->actions as $action) { $node->append($action->getConfigTreeBuilder()->getRootNode()); diff --git a/src/Service.php b/src/Service.php index e55a0ca8..32bc011c 100644 --- a/src/Service.php +++ b/src/Service.php @@ -325,8 +325,8 @@ private function compilePipelineJob(array $config): Satellite\Builder\Repository $repository = new Satellite\Builder\Repository\Pipeline($pipeline); $repository->addPackages( - 'php-etl/pipeline-contracts:0.4.*', - 'php-etl/pipeline:*', + 'php-etl/pipeline-contracts:dev-main', + 'php-etl/pipeline:dev-main', 'php-etl/console-state:*', 'php-etl/pipeline-console-runtime:*', 'php-etl/workflow-console-runtime:*', From 7cd25c3c22bca76c929760232e58aaeb6ae00d92 Mon Sep 17 00:00:00 2001 From: GitHub Action Date: Tue, 21 Nov 2023 23:29:20 +0000 Subject: [PATCH 2/2] [rector] Rector fixes --- src/Adapter/Docker/Satellite.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Adapter/Docker/Satellite.php b/src/Adapter/Docker/Satellite.php index f551d427..9ae97a02 100644 --- a/src/Adapter/Docker/Satellite.php +++ b/src/Adapter/Docker/Satellite.php @@ -73,7 +73,7 @@ public function build( $command = ['docker', 'build', '--rm', '-', ...iterator_to_array($iterator($this->imageTags))]; $process = new Process( - implode (' ', array_map(fn ($part) => escapeshellarg($part), $command)), + implode (' ', array_map(fn ($part) => escapeshellarg((string) $part), $command)), $this->workdir, );