thewebsolver/pipeline

Follows Chain of Responsibility Design Pattern to handle the given subject/request.

v2.0 2024-12-24 07:32 UTC

This package is auto-updated.

Last update: 2024-12-25 07:31:53 UTC


README

TheWebSolver Pipeline library follows the 🔗 Chain of Responsibility Design Pattern 🔗 to handle the given subject/request using pipes. The pipeline can accept any subject type, passes it through provided pipes and return the updated subject back.

Installation (via Composer)

Install library using composer command:

$ composer require thewebsolver/pipeline

Benefits

  • Follows Chain of Responsibility design pattern by passing subject to pipeline handlers in order they were stacked.

    Use Pipeline::through() method to pass main handlers as pipe. Optionally, pass additional handlers using Pipeline::pipe() method.

  • Provides support for additional arguments that can be accepted by each handler passed using above methods.

    Use Pipeline::use() method to pass as many arguments as required.

  • Provides support for catching Pipe Exception or Unexpected Exception thrown by the handler.

    Use Pipeline::sealWith() method to pass a closure to handle thrown exception.

  • Provides bridge for PHP Projects that implements PSR-7, PSR-15 (optional PSR-11) standards.

    Use Queue based Request Handler implementation to handle stacked middlewares inside Request Handler's handle method (RequestHandlerInterface::handle()).

Usage

For usage details, visit Wiki page.