Easily add an approval process to any laravel model.
Laravel Approvable is a package which helps when you have certain models in your application that should be editable by users, but the fields that they edit need to be approved first.
Via Composer
$ composer require victorlap/laravel-approvable
You can publish the migration with:
php artisan vendor:publish --provider="Victorlap\Approvable\ApprovableServiceProvider" --tag="migrations"
php artisan migrate
Assume you have a Post
model. Each visitor on your site can edit any post, but before you want to publish the change to your website, you want to approve it first. By adding the \Victorlap\Approvable\Approvable
trait to your Post
model, when a visitor makes a change, a change request gets stored in the database. These changes can then later be applied, or denied by administrators. The currentUserCanApprove
method can be used to determine who is authorized to make a change.
use Illuminate\Database\Eloquent\Model;
use Victorlap\Approvable\Approvable;
// Minimal
class Post extends Model
{
use Approvable;
}
// Extended
class Post extends Model
{
use Approvable;
protected $approveOf = array();
protected $dontApproveOf = array();
protected function currentUserCanApprove()
{
return Auth::check();
}
protected function getSystemUserId()
{
return Auth::id();
}
}
Making a change to a model by a user who can approve does not change.
$post->title = "Very Good Post";
$post->save(); // This still works!
Making a change by an unauthorized user works the same.
$post->title = "Very Good Post";
$post->save(); // Post remains with the old title in the database, however a change request is now also present.
You can retrieve a list of attributes that have pending changes by using
$post->getPendingApprovalAttributes();
Or check if a certain attribute has pending changes
$post->isPendingApproval('title');
Scopes have been defined to quickly see approvals in different states. For example if you wnat to show administrators a list with changes that can be accepted you can use the open
scope. Other scopes are accepted
, rejected
and ofClass
.
Approval::open()->get();
Approval::accepted()->get();
Approval::rejected()->get();
Approval::ofClass(Post::class)->get();
You can combine the scopes of course, or use them in combination with regular query builder methods
Approval::open()->ofClass(Post::class)->get();
Accepting and rejecting of approvals can be done using the accept
and reject
methods on the Approval.
$approvals = Post::find(1)->approvals()->open()->get();
$approvals->each->accept(); // or
$approvals->each->reject();
If you dont want a model to pass approval, you can use the withoutApproval()
method.
// Now this post model is not checked for changes.
$post->withoutApproval()
->fill([
'title' => 'A new title',
])
->save();
To re-enable the approval for this model instance, you can use the withApproval()
method.
Currently Approvable does not handle creation of models, PR's are welcome for this.
Please see CHANGELOG for more information on what has changed recently.
$ composer test
Please see CONTRIBUTING and CONDUCT for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.