plank / laravel-schema-events
A Laravel package to emit events based on the schema changes taking place during migration.
Fund package maintenance!
Plank
Requires
- php: ^8.2
- illuminate/contracts: ^11.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1
- orchestra/testbench: ^9.0.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
README
Laravel Schema Events
Track and respond to database schema changes in your Laravel application through a simple event system.
Table of Contents
- Installation
- Quick Start
- Configuration
- Usage
- Contributing
- Credits
- License
- Security Vulnerabilities
- About Plank
Installation
You can install the package via composer:
composer require plank/laravel-schema-events
You can publish the config file with:
php artisan vendor:publish --tag="schema-events-config"
Quick Start
- Install the package
- Set up an event listener:
<?php namespace App\Listeners; use Plank\LaravelSchemaEvents\Events\TableCreated; class LogTableCreation { public function handle(TableCreated $event) { \Log::info("Table {$event->table} was created with columns: " . implode(', ', $event->columns->toArray())); } }
- Register your listener in
EventServiceProvider.php
:
protected $listen = [ TableCreated::class => [ LogTableCreation::class, ], ];
Configuration
The configuration file allows you to customize:
- Which migration events to listen for
- Which commands are tracked for different schema operations
return [ 'listeners' => [ 'ran' => MigrationRan::class, 'finished' => MigrationsFinished::class, ], 'commands' => [ 'renamed_columns' => ['renameColumn'], 'dropped_columns' => ['dropColumn'], 'added_indexes' => [ 'primary', 'unique', 'index', 'fulltext', 'spatialIndex', ], // ... additional commands ], ];
Usage
Available Events
The package provides four main events:
TableCreated
- Emitted when a new table is createdTableChanged
- Emitted when an existing table is modifiedTableDropped
- Emitted when a table is droppedTableRenamed
- Emitted when a table is renamed
Event Properties
Each event includes basic connection information:
connection
- The name of the database connectiondatabaseName
- The name of the databasedriverName
- The database driver being used
TableCreated Event
public readonly string $table; public readonly Collection $columns; // Added columns public readonly Collection $indexes; // Added indexes public readonly Collection $foreignKeys; // Added foreign keys
TableChanged Event
public readonly string $table; public readonly Collection $addedColumns; public readonly Collection $droppedColumns; public readonly Collection $renamedColumns; // Contains [from => x, to => y] public readonly Collection $modifiedColumns; public readonly Collection $addedIndexes; public readonly Collection $droppedIndexes; public readonly Collection $renamedIndexes; // Contains [from => x, to => y] public readonly Collection $addedForeignKeys; public readonly Collection $droppedForeignKeys;
TableDropped Event
public readonly string $table;
TableRenamed Event
public readonly string $from; public readonly string $to;
Contributing
Please see CONTRIBUTING for details.
Credits
License
The MIT License (MIT). Please see License File for more information.
Security Vulnerabilities
If you discover a security vulnerability within siren, please send an e-mail to security@plank.co. All security vulnerabilities will be promptly addressed.
Check Us Out!
Plank focuses on impactful solutions that deliver engaging experiences to our clients and their users. We're committed to innovation, inclusivity, and sustainability in the digital space. Learn more about our mission to improve the web.