Package Data | |
---|---|
Maintainer Username: | acacha |
Maintainer Contact: | mike.hj.rice@gmail.com (Mike Rice) |
Package Create Date: | 2016-11-20 |
Package Last Update: | 2018-01-12 |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2025-01-21 03:13:19 |
Package Statistics | |
---|---|
Total Downloads: | 7,152 |
Monthly Downloads: | 1 |
Daily Downloads: | 0 |
Total Stars: | 11 |
Total Watchers: | 3 |
Total Forks: | 6 |
Total Open Issues: | 1 |
If you're familiar with my AASM, then this is a similar take – just implemented in Laravel 5 for Eloquent classes.
Forked from https://github.com/mikerice/stateful-eloquent
composer require acacha/stateful-eloquent
Acacha\Stateful\Providers\StatefulServiceProvider::class,
Your models should use the Stateful trait and interface
use Acacha\Stateful\Traits\StatefulTrait;
use Acacha\Stateful\Contracts\Stateful;
class Transaction extends Model implements Stateful
{
use StatefulTrait;
}
Your models should have an array name $states
that define your model states.
/**
* Transaction States
*
* @var array
*/
protected $states = [
'draft' => ['initial' => true],
'processing',
'errored',
'active',
'closed' => ['final' => true]
];
/**
* Transaction State Transitions
*
* @var array
*/
protected $transitions = [
'process' => [
'from' => ['draft', 'errored'],
'to' => 'processing'
],
'activate' => [
'from' => 'processing',
'to' => 'active'
],
'fail' => [
'from' => 'processing',
'to' => 'errored'
],
'close' => [
'from' => 'active',
'to' => 'close'
]
];
/**
* @return bool
*/
protected function validateProcess()
{
$validate = true;
if (!$validate) {
$this->addValidateProcessMessage();
}
return $validate;
}
/**
* @return bool
*/
protected function validateActivate()
{
//dd("validateActivate");
return true;
}
/**
* @return bool
*/
protected function validateFail()
{
//dd("validateFail");
return true;
}
/**
* @return bool
*/
protected function validateClose()
{
//dd("validateClose");
return true;
}
protected function beforeProcess() {
//dd("doing something before entering processing state");
}
protected function afterProcess() {
//dd("doing something after leaving processing state");
}
You model migration should have a state field like:
class CreateModelTable extends Migration
{
/**
* Run the migrations.
*
* @return void
*/
public function up()
{
Schema::create('model', function (Blueprint $table) {
$table->increments('id');
...
$table->string('state');
...
$table->timestamps();
});
}
$transaction = new Transaction();
//Execute transition
$transaction->process();
//Check if a state is active (return true or false)
$transaction->active();