kakhura / laravel-workflow
Integerate Symfony Workflow component into Laravel.
3.0.0
2023-08-01 11:18 UTC
Requires
- php: >=5.5.9
- illuminate/console: 5.3.* || 5.4.* || 5.5.* || 5.6.* || 5.7.* || 5.8.* || 6.* || 7.* || 8.* || 9.* || 10.*
- illuminate/support: 5.3.* || 5.4.* || 5.5.* || 5.6.* || 5.7.* || 5.8.* || 6.* || 7.* || 8.* || 9.* || 10.*
- symfony/event-dispatcher: ^3.3 || ^4.0 || ^5.0 || ^6.3
- symfony/process: ^3.3 || ^4.0 || ^5.0 || ^6.3
- symfony/workflow: ^3.3 || ^4.0 || ^5.0 || ^6.3
Requires (Dev)
- mockery/mockery: ^1.0
- phpunit/phpunit: ^6.0 || ~7.0 || ^8.0
README
Use the Symfony Workflow component in Laravel
Installation
composer require brexis/laravel-workflow
For laravel <= 5.4
Add a ServiceProvider to your providers array in config/app.php
:
<?php 'providers' => [ ... Brexis\LaravelWorkflow\WorkflowServiceProvider::class, ]
Add the Workflow
facade to your facades array:
<?php ... 'Workflow' => Brexis\LaravelWorkflow\Facades\WorkflowFacade::class,
Configuration
Publish the config file
php artisan vendor:publish --provider="Brexis\LaravelWorkflow\WorkflowServiceProvider"
Configure your workflow in config/workflow.php
<?php return [ 'straight' => [ 'type' => 'workflow', // or 'state_machine' 'marking_store' => [ 'type' => 'multiple_state', 'arguments' => ['currentPlace'] ], 'supports' => ['App\BlogPost'], 'places' => ['draft', 'review', 'rejected', 'published'], 'transitions' => [ 'to_review' => [ 'from' => 'draft', 'to' => 'review' ], 'publish' => [ 'from' => 'review', 'to' => 'published' ], 'reject' => [ 'from' => 'review', 'to' => 'rejected' ] ], ] ];
Use the WorkflowTrait
inside supported classes
<?php namespace App; use Illuminate\Database\Eloquent\Model; use Brexis\LaravelWorkflow\Traits\WorkflowTrait; class BlogPost extends Model { use WorkflowTrait; }
Usage
<?php use App\BlogPost; use Workflow; $post = BlogPost::find(1); $workflow = Workflow::get($post); // if more than one workflow is defined for the BlogPost class $workflow = Workflow::get($post, $workflowName); $workflow->can($post, 'publish'); // False $workflow->can($post, 'to_review'); // True $transitions = $workflow->getEnabledTransitions($post); // Apply a transition $workflow->apply($post, 'to_review'); $post->save(); // Don't forget to persist the state // Using the WorkflowTrait $post->workflow_can('publish'); // True $post->workflow_can('to_review'); // False // Get the post transitions foreach ($post->workflow_transitions() as $transition) { echo $transition->getName(); } // if more than one workflow is defined for the BlogPost class foreach ($post->workflow_transitions($workflowName) as $transition) { echo $transition->getName(); } // Apply a transition $post->workflow_apply('publish'); $post->save();
Use the events
This package provides a list of events fired during a transition
Brexis\LaravelWorkflow\Events\Guard Brexis\LaravelWorkflow\Events\Leave Brexis\LaravelWorkflow\Events\Transition Brexis\LaravelWorkflow\Events\Enter Brexis\LaravelWorkflow\Events\Entered
You can subscribe to an event
<?php namespace App\Listeners; use Brexis\LaravelWorkflow\Events\GuardEvent; class BlogPostWorkflowSubscriber { /** * Handle workflow guard events. */ public function onGuard(GuardEvent $event) { /** Symfony\Component\Workflow\Event\GuardEvent */ $originalEvent = $event->getOriginalEvent(); /** @var App\BlogPost $post */ $post = $originalEvent->getSubject(); $title = $post->title; if (empty($title)) { // Posts with no title should not be allowed $originalEvent->setBlocked(true); } } /** * Handle workflow leave event. */ public function onLeave($event) {} /** * Handle workflow transition event. */ public function onTransition($event) {} /** * Handle workflow enter event. */ public function onEnter($event) {} /** * Handle workflow entered event. */ public function onEntered($event) {} /** * Register the listeners for the subscriber. * * @param Illuminate\Events\Dispatcher $events */ public function subscribe($events) { $events->listen( 'Brexis\LaravelWorkflow\Events\GuardEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onGuard' ); $events->listen( 'Brexis\LaravelWorkflow\Events\LeaveEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onLeave' ); $events->listen( 'Brexis\LaravelWorkflow\Events\TransitionEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onTransition' ); $events->listen( 'Brexis\LaravelWorkflow\Events\EnterEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onEnter' ); $events->listen( 'Brexis\LaravelWorkflow\Events\EnteredEvent', 'App\Listeners\BlogPostWorkflowSubscriber@onEntered' ); } }
Dump Workflows
Symfony workflow uses GraphvizDumper to create the workflow image. You may need to install the dot
command of Graphviz
php artisan workflow:dump workflow_name --class App\\BlogPost
You can change the image format with the --format
option. By default the format is png.
php artisan workflow:dump workflow_name --format=jpg