szykra/state-machine
最新稳定版本:0.1.0
Composer 安装命令:
composer require szykra/state-machine
包简介
Simple Finite State Machine implementation
README 文档
README
Finite State Machine implementation in PHP
Installation
Install via composer
Add dependency to your composer.json file and run composer update.
"szykra/state-machine": "~0.1.0"
or just run
composer require szykra/state-machine
Usage
Prepare your entity to be stateful
Your entity should implements interface StatefulInterface. It requires two new methods
public function getState();public function setState($state);
Of course you should add new property named e.g. state.
Configure a StateMachine by adding States and Transitions
To control your entity by StateMachine you have to define:
- States
- Transitions between States
State
State object simply represents a state. It has name and list of available transitions.
$stateDraft = new State('draft'); $statePublished = new State('published');
Transition
Transition is like single action which someone performs on an object. It means transition from one state to another state.
$stateDraft->addTransition('publish', 'draft', 'published'); $transitionReject = new Transition('reject', 'published', 'rejected'); $statePublished->putTransition($transitionReject);
Each state has own transitions so available transitions depend on the current state of object.
StateMachine
StateMachine is a controller used to change state of stateful object. First you should create a StateMachine object and set up it by adding a valid States.
$stateMachine = new StateMachine(); // api inconsistent, should called putState $stateMachine->addState($stateDraft); $stateMachine->addState($statePublished);
Initialize a State Machine
When your StateMachine is ready you could initialize it by Stateful Object.
$document = new Document(); $stateMachine->initialize($document);
Now you could change state of $document by $stateMachine. To check if transition can be performed use the can($transition) method, e.g. if current state of $document is draft the results will be as follows
$stateMachine->can('publish'); // true $stateMachine->can('reject'); // false
To change state of object you should use run($transition) method. If transition not exists TransitionNotFoundException will be thrown.
echo $document->getState(); // draft $stateMachine->run('publish'); echo $document->getState(); // published
If you want to see a complete example please see tests/ directory.
To do
- Ability to setup callbacks before/after change states
- List all states
- List all transitions
- Add configurable loader to StateMachine
- Add configurable conditionals to transitions
License
The MIT License. Copyright © 2015 by Szymon Krajewski
统计信息
- 总下载量: 14
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 1
- 点击次数: 1
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-08-20