The preferred way to install this extension is through composer.
Either run
php composer.phar require --prefer-dist hjp1011/yii2-workflow "*"
or add
"hjp1011/yii2-workflow": "*"
to the require section of your composer.json
file.
For this "Quick start Guide" we will be using default configuration settings, but remember that yii2-workflow is designed to be highly flexible so to adapt to a lot of execution contexts... well at least that was my goal.
A workflow is defined as a PHP class that implements the \hjp1011\workflow\source\file\IWorkflowDefinitionProvider
interface. which
declares the getDefinition() method. This method must return an array representing the workflow definition.
Let's define a very simple workflow that will be used to manage posts in a basic blog system.
Here is the PHP class that implements the definition for our workflow :
@app/models/PostWorkflow.php
namespace app\models;
class PostWorkflow implements \hjp1011\workflow\source\file\IWorkflowDefinitionProvider
{
public function getDefinition() {
return [
'initialStatusId' => 'draft',
'status' => [
'draft' => [
'transition' => ['publish','deleted']
],
'publish' => [
'transition' => ['draft','deleted']
],
'deleted' => [
'transition' => ['draft']
]
]
];
}
}
Now let's have a look to our Post model: we store the status of a post in a column named status
of type STRING(40).
The last step is to associate the workflow definition with posts models. To do so we must declare the SimpleWorkflowBehavior behavior in the Post model class and let the default configuration settings do the rest.
@app/models/Post.php
namespace app\models;
/**
* @property integer $id
* @property string $title
* @property string $body
* @property string $status column used to store the status of the post
*/
class Post extends \yii\db\ActiveRecord
{
public function behaviors()
{
return [
\hjp1011\workflow\base\SimpleWorkflowBehavior::className()
];
}
// ...
That's it ! We are ready to play with SimpleWorkflowBehavior.
Now that we are all setup, we can use the SimpleWorkflowBehavior methods to set/get the status of our posts : the SimpleWorkflowBehavior will take care that the post doesn't reach a status where it is not supposed to go to, depending on the workflow definition that we have provided.
$post = new Post();
$post->status = 'draft';
$post->save();
echo 'post status is : '. $post->workflowStatus->label;
This will print the following message :
post status is : Draft
If you do the same thing but instead of draft set the status to publish and try to save it, the following exception is thrown :
Not an initial status : PostWorkflow/publish ("PostWorkflow/draft" expected)
That's because in your workflow definition the initial status is set to draft and not publish.
Ok, one more example for the fun ! This time we are not going to perform the transition when the Post is saved (like we did in the previous
example), but immediately, by invoking the sendToStatus
method. Our Post is going to try to reach status publish passing through deleted
which is strictly forbidden by the workflow. Will it be successful in this risky attempt to break workflow rules ?
$post = new Post();
$post->sendToStatus('draft');
$post->sendToStatus('deleted');
$post->sendToStatus('publish'); // danger zone !
Game Over ! There is no transition between deleted and publish, and that's what SimpleWorkflow tries to explain to our fearless post object.
Workflow Exception – hjp1011\workflow\base\WorkflowException
No transition found between status PostWorkflow/deleted and PostWorkflow/publish
Yes, that's severe, but there was many ways to avoid this exception like for instance by first validating that the transition was possible.
This is just one way of using the SimpleWorkflowBehavior but there's much more and hopefully enough to assist you in workflow management inside your Yii2 web app.
You may also be interested in the following projects developed around yii2-workflow :
- yii2-workflow-view : A Widget to display workflows
yii2-workflow is released under the BSD 3-Clause License. See the bundled LICENSE.md
for details.