承接 sfolador/laravel-locked 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

sfolador/laravel-locked

最新稳定版本:0.5.1

Composer 安装命令:

composer require sfolador/laravel-locked

包简介

This package adds locking features to Eloquent Models

README 文档

README

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

Laravel Locked

A package to add locking features to Eloquent Models.

Installation

You can install the package via composer:

composer require sfolador/laravel-locked

You can publish the config file with:

php artisan vendor:publish --tag="locked-config"

This is the contents of the published config file:

return [
   'locking_column' => 'locked_at',
   
    'default_namespace' => 'App\Models',

    'unlock_allowed' => true,
    'can_be_unlocked' => [
    ],
    
    'prevent_modifications_on_locked_objects' => false,
];

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 :

php artisan lock-add {classname} {--namespace=}

For example, if you want to add a locking column to the User model, you can run the command :

php artisan lock-add User

This will create a migration file in the database/migrations folder, you can then run the migration with :

php artisan migrate

The command accepts an optional --namespace parameter, to specify the namespace of the class, for example :

php artisan lock-add User --namespace=App\Models\SomeFolder

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.

use Sfolador\Locked\Traits\HasLocks;

class User extends Model
{
    use HasLocks;
}

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 date
  • unlock(): removes the lock by setting the locking column to null
  • isLocked(): returns true if the model is locked, false otherwise
  • isUnlocked(): returns true if the model is unlocked, false otherwise
  • isNotUnlocked(): returns true if the model is not unlocked, false otherwise
  • isNotLocked(): returns true if the model is not locked, false otherwise
  • toggleLock(): toggles the lock state of the model

Example

$user = User::find(1);
$user->lock();

//...

if ($user->isNotLocked()) {
   UserManager::update($user);
}

Todo

  • Add an option to forbid locking a model if it is already locked and raise an Exception
  • Add an option to block notifications to the model if it is locked
  • Add logging to locking/unlocking actions for auditing purposes
  • Add an option to block the model saving if it is locked

Testing

composer test

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.

统计信息

  • 总下载量: 207
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 42
  • 点击次数: 2
  • 依赖项目数: 1
  • 推荐数: 0

GitHub 信息

  • Stars: 41
  • Watchers: 1
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-11-13

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固