Download the PHP package sfolador/laravel-locked without Composer
On this page you can find all versions of the php package sfolador/laravel-locked. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download sfolador/laravel-locked
More information about sfolador/laravel-locked
Files in sfolador/laravel-locked
Package laravel-locked
Short Description This package adds locking features to Eloquent Models
License MIT
Homepage https://github.com/sfolador/laravel-locked
Informations about the package laravel-locked
Locked eloquent models
A package to add locking features to Eloquent Models.
Installation
You can install the package via composer:
You can publish the config file with:
This is the contents of the published config file:
You can choose another default column name for the locking column by changing the locking_column
value.
The default_namespace
value is used to automatically add the namespace to the model passed as an argument to the Command. See the Usage section for more details.
The unlock_allowed
value is used to enable or disable the unlock
command. If you set it to false
, the unlock
method will raise an exception.
It's possible to add a whitelist of models that can be unlocked by setting the can_be_unlocked
array.
If the array is empty and the unlock_allowed
value is false
, no model can be unlocked.
The prevent_modifications_on_locked_objects
value is used to forbid modifications on locked models.
If you set it to true
, an exception will be raised if you try to save/delete/replicated a locked model.
Command
There is an artisan command to create a migration for a class, run the command with :
For example, if you want to add a locking column to the User
model, you can run the command :
This will create a migration file in the database/migrations
folder, you can then run the migration with :
The command accepts an optional --namespace
parameter, to specify the namespace of the class, for example :
The default namespace for the command is App\Models
but you can change it in the config file by modifying the default_namespace
value.
Usage
Once created the migration, you can use the Lockable
trait in your model.
this trait will add the following methods to your model :
lock()
: adds a lock to the model by setting the locking column to the current dateunlock()
: removes the lock by setting the locking column to nullisLocked()
: returns true if the model is locked, false otherwiseisUnlocked()
: returns true if the model is unlocked, false otherwiseisNotUnlocked()
: returns true if the model is not unlocked, false otherwiseisNotLocked()
: returns true if the model is not locked, false otherwisetoggleLock()
: toggles the lock state of the model
Example
Todo
- [x] Add an option to forbid locking a model if it is already locked and raise an Exception
- [x] Add an option to block notifications to the model if it is locked
- [ ] Add logging to locking/unlocking actions for auditing purposes
- [x] Add an option to block the model saving if it is locked
Testing
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.
All versions of laravel-locked with dependencies
spatie/laravel-package-tools Version ^1.13.0
illuminate/contracts Version ^9.0|^10