danielemontecchi/laravel-patcher 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

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

danielemontecchi/laravel-patcher

最新稳定版本:v1.1.3

Composer 安装命令:

composer require danielemontecchi/laravel-patcher

包简介

A predictable system for applying one-time operational or data patches in Laravel—trackable, skippable, and rollback-ready.

README 文档

README

Latest Version on Packagist Total Downloads GitHub Tests Action Status Quality Gate Status License: MIT Documentation

Laravel Patcher is a clean and predictable system for applying one-time patches to your Laravel application. It works similarly to migrations but is designed for operational, data-related, or procedural logic that you need to run once and track.

Inspired by Taylor Otwell’s patching concept, this package formalizes and extends the idea to support a wide variety of use cases, including conditionally skipped patches, tracking applied states, and batch rollback.

Features

  • Runs patch classes similar to migrations
  • Supports anonymous class patches using return new class extends Patch
  • Automatically tracks execution via the patches database table
  • Supports conditional execution via shouldRun()
  • Distinguishes executed vs skipped patches using is_applied
  • CLI output styled identically to php artisan migrate
  • Allows rollback by batch

Installation

composer require danielemontecchi/laravel-patcher

Laravel will automatically register the service provider.

To create the required database table, run:

php artisan migrate

Patch Table Format

The patches table includes:

Column Type Description
id bigint Auto-increment primary key
name string Patch filename (without .php)
batch int Batch number (like migrations)
is_applied boolean Whether shouldRun() returned true and the patch was executed
applied_at timestamp When the patch was recorded

Skipped patches are still recorded, but with is_applied = false.

Creating a Patch

php artisan make:patch FixUsernames

This will generate a new file in database/patches/:

<?php

use DanieleMontecchi\LaravelPatcher\Contracts\Patch;

return new class extends Patch {
    public function shouldRun(): bool {
        return true; // Logic to determine if patch should run
    }

    public function up(): void {
        // Logic to apply
    }

    public function down(): void {
        // Logic to rollback
    }
};

Patches must return an anonymous class instance that extends Patch.

Executing Patches

php artisan patch

Executes all unapplied patches, skipping those already registered in the patches table. Patches for which shouldRun() returns false are marked as skipped and recorded accordingly.

Rolling Back Patches

php artisan patch:rollback

Rolls back the latest batch of applied patches (only those where is_applied = true).

Use the --step=N option to rollback multiple batches:

php artisan patch:rollback --step=2

License

Laravel Patcher is open-source software licensed under the MIT license. See the LICENSE.md file for full details.

Made with ❤️ by Daniele Montecchi

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-05-08