Download the PHP package roquie/pipeline without Composer
On this page you can find all versions of the php package roquie/pipeline. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download roquie/pipeline
More information about roquie/pipeline
Files in roquie/pipeline
Package pipeline
Short Description A plug and play pipeline implementation.
License MIT
Informations about the package pipeline
Roquie\Pipeline
This package provides a pipeline pattern implementation.
Pipeline Pattern
The pipeline pattern allows you to easily compose sequential stages by chaining stages.
In this particular implementation the interface consists of two parts:
- StageInterface
- PipelineInterface
A pipeline consists of zero, one, or multiple stages. A pipeline can process a payload. During the processing the payload will be passed to the first stage. From that moment on the resulting value is passed on from stage to stage.
In the simplest form, the execution chain can be represented as a foreach:
Immutability
Pipelines are implemented as immutable stage chains. When you pipe a new stage, a new pipeline will be created with the added stage. This makes pipelines easy to reuse, and minimizes side-effects.
Simple Example
Re-usable Pipelines
Because the PipelineInterface is an extension of the StageInterface pipelines can be re-used as stages. This creates a highly composable model to create complex execution patterns while keeping the cognitive load low.
For example, if we'd want to compose a pipeline to process API calls, we'd create something along these lines:
Callable Stages
The CallableStage
class is supplied to encapsulate parameters which satisfy
the callable
type hint. This class enables you to use any type of callable as a
stage.
Pipeline Builders
Because pipelines themselves are immutable, pipeline builders are introduced to facilitate distributed composition of a pipeline.
The pipeline builders collect stages and allow you to create a pipeline at any given time.
Exception handling
This package is completely transparent when dealing with exceptions. In no case will this package catch an exception or silence an error. Exceptions should be dealt with on a per-case basis. Either inside a stage or at the time the pipeline processes a payload.