juststeveking / laravel-business-process
Laravel Business Process is a simple and clean way to run business process using a Laravel Pipeline, in a structured and type-safe way.
Fund package maintenance!
JustSteveKing
Installs: 2 609
Dependents: 0
Suggesters: 0
Security: 0
Stars: 67
Watchers: 4
Forks: 1
Open Issues: 1
Requires
- php: ^8.2
Requires (Dev)
- laravel/pint: ^1.9
- orchestra/testbench: ^8.5
- pestphp/pest: ^2.5.2
- phpstan/phpstan: ^1.10.14
README
Laravel Business Process is a simple and clean way to run business process using a Laravel Pipeline, in a structured and type-safe way.
This package is inspired by the tutorial I wrote for Laravel News Going Past Actions in Laravel.
Installation
composer require juststeveking/laravel-business-process
Usage
To get started with this package, all you need to do is create a new process class:
use JustSteveKing\BusinessProcess\Process; final class PurchaseProduct extends Process { protected array $tasks = [ CheckStockLevel::class, ProcessOrder::class, DecreaseStockLevel::class, NotifyWarehouse::class, EmailCustomer::class, ]; }
Our process class registers the tasks that need to be completed for this process to run, each task must implement the TaskContract
interface that comes with this package.
use JustSteveKing\BusinessProcess\Contracts\TaskContract; final class CheckStockLevel implements TaskContract { public function __invoke(ProcessPayload $payload, Closure $next): mixed { // perform your logic here with the passed in payload. return $next($payload); } }
Your tasks are standard classes that the Pipeline
class from Laravel would expect.
The payload is a class that implements ProcessPayload
interface, signalling that it is a payload for a process. They are simple plain old PHP classes with no requirements to add methods.
use JustSteveKing\BusinessProcess\Contracts\ProcessPayload; final class PurchaseProductPayload implements ProcessPayload { public function __construct( // add whatever public properties you need here public int $product, public int $user, public int $order, ) {} }
Finally, we can call this process within our controller/job/cli wherever you need to.
final class PurchaseController { public function __construct( private readonly PurchaseProduct $process, ) {} public function __invoke(PurchaseRequest $request, int $product): JsonResponse { try { $this->process->run( payload: $request->payload(), ); } catch (Throwable $exception) { // Handle exception } // return response. } }
Testing
To run the test:
composer run test
Credits
LICENSE
The MIT License (MIT). Please see License File for more information.