版本控制系统 - Versionable

版本控制系统 - Versionable

Laravel 模型版本管理,从未如此简单

codecov.io Scrutinizer Code Quality Build Status

Versionable 是一个用于 Laravel 的库,可帮助你轻松追踪和恢复模型的所有更改记录。

// 回滚到上一版本
$content->previousVersion()->revert();

// 根据版本获取模型
$oldModel = Version::find(100)->getModel();

安装与配置

通过 Composer 进行安装:

composer require mpociot/versionable

然后运行迁移文件:

php artisan migrate --path=vendor/mpociot/versionable/src/migrations

或者发布并运行迁移文件:

php artisan vendor:publish --provider="Mpociot\Versionable\Providers\ServiceProvider" --tag="migrations"
php artisan migrate

使用方法

在你想进行版本控制的模型中,引入 VersionableTrait

class Content extends Model {

    use Mpociot\Versionable\VersionableTrait;

}

这样就完成了!

每次更新模型时,新的版本都会保存当前的属性信息在数据库中。

现有数据的版本化

如果你的应用已经有了一些历史数据,可以使用 createInitialVersion() 方法为现有模型创建初始版本,或者使用 Model::initializeVersions() 来批量处理。

排除字段

有些情况下,不希望每个属性变动都创建新版本,例如在用户模型中可能有一个 last_login_at 字段,你不希望每次登录都创建新版本。你可以通过设置模型上的 dontVersionFields 属性来排除这些字段。

class User extends Model {

    use VersionableTrait;

    /**
     * @var array
     */
    protected $dontVersionFields = [ 'last_login_at' ];

}

隐藏字段版本化

有时你需要将通常隐藏的字段(如 hiddenvisible 属性)存储在版本信息中,可以通过在版战控制模型上定义 versionedHiddenFields 属性实现。

最大存储版本数

你可以控制每个模型的最大存储版本数量,默认没有限制。如果需要设定上限,可在模型中添加 $keepOldVersions 属性。

class User {

    use VersionableTrait;

    // 保留最近10个版本。
    protected $keepOldVersions = 10;

}

获取版本差异

使用 diff 方法查看两个版本之间的差异,结果会以关联数组的形式返回,键是字段名,值是变化后的值。

版本回滚

你可以轻松地回滚至之前的版本,例如:

$content->previousVersion()->revert();

或回滚至特定ID的版本:

$revertedModel = Version::find($version_id)->revert();

关闭版本控制

某些情况下,你可能希望在特定请求中暂时关闭某个模型的版本控制,这可以通过模型的 disableVersioningenableVersioning 方法完成。

自定义版本表

如有需要,你可以为特定模型的版本信息使用不同的表格,只需创建一个新的版本模型类,重设 $table 属性,并在原模型中设置 $versionClass 属性指向这个自定义版本模型。

特点总结
  • 易于集成,只须在模型中引入一个 Trait。
  • 可灵活设置版本控制策略,比如排除字段、最大版本数等。
  • 支持查看版本间的差异,方便对比和回滚。
  • 内置了对隐藏字段的版本化支持。
  • 提供了关闭版本控制的功能,适用于特殊情况需求。

Versionable 提供了一套优雅的解决方案,让 Laravel 应用中的数据版本控制变得轻而易举。无论是用于跟踪用户数据的变更,还是用于确保文档系统的版本一致性,都将助你事半功倍。现在就尝试一下吧!

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

姚婕妹

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值