jimchen/laravel-trigger

MySQL trigger base on MySQLReplication

Maintainers

πŸ‘ jimchen

Package info

github.com/JimChenWYU/laravel-trigger

Homepage

pkg:composer/jimchen/laravel-trigger

Statistics

Installs: 87

Dependents: 0

Suggesters: 0

Stars: 1

Open Issues: 0

v1.0.0 2020-05-24 02:21 UTC

Requires

Requires (Dev)

None

Suggests

None

Provides

None

Conflicts

None

Replaces

None

MIT b426f6549e4b205d1b2000eeb6fcf786590a74a3

  • huangdijia <huangdijia.woop@gmail.com>
  • jimchen <imjimchen.woop@163.com>

mysqllaraveltrigger

This package is auto-updated.

Last update: 2026-06-24 17:13:54 UTC


README

πŸ‘ Latest Stable Version
πŸ‘ Total Downloads
πŸ‘ GitHub license

Subscribe MySQL events like jQuery, base on php-mysql-replication

δΈ­ζ–‡θ―΄ζ˜Ž

MySQL server settings

In your MySQL server configuration file you need to enable replication:

[mysqld]
server-id = 1
log_bin = /var/log/mysql/mysql-bin.log
expire_logs_days = 10
max_binlog_size = 100M
binlog_row_image = full
binlog-format = row #Very important if you want to receive write, update and delete row events
Mysql replication events explained https://dev.mysql.com/doc/internals/en/event-meanings.html

Mysql user privileges:

GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'user'@'host';

GRANT SELECT ON `dbName`.* TO 'user'@'host';

Installation

Laravel

install

composer require jimchen/laravel-trigger

publish config

php artisan vendor:publish --provider="JimChen\Trigger\TriggerServiceProvider"

Lumen

install

composer require jimchen/laravel-trigger

edit bootstrap/app.php add:

$app->register(JimChen\Trigger\TriggerServiceProvider::class);
...
$app->configure('trigger');

publish config and route

php artisan trigger:install [--force]

Configure

edit .env, add:

TRIGGER_HOST=192.168.xxx.xxx
TRIGGER_PORT=3306
TRIGGER_USER=username
TRIGGER_PASSWORD=password
...

Usage

php artisan trigger:start [-R=xxx]

Subscriber

<?php
namespace App\Listeners;

use JimChen\Trigger\EventSubscriber;

class ExampeSubscriber extends EventSubscriber
{
 public function onUpdate(UpdateRowsDTO $event)
 {
 //
 }

 public function onDelete(DeleteRowsDTO $event)
 {
 //
 }

 public function onWrite(WriteRowsDTO $event)
 {
 //
 }
}

more subscriber usage

EventSubscribers

Event Route

common

$trigger->on('database.table', 'write', function($event) { /* do something */ });

multi-tables and multi-evnets

$trigger->on('database.table1,database.table2', 'write,update', function($event) { /* do something */ });

multi-events

$trigger->on('database.table1,database.table2', [
 'write' => function($event) { /* do something */ },
 'update' => function($event) { /* do something */ },
]);

action as controller

$trigger->on('database.table', 'write', 'App\\Http\\Controllers\\ExampleController'); // call default method 'handle'
$trigger->on('database.table', 'write', 'App\\Http\\Controllers\\ExampleController@write');

action as callable

class Foo
{
 public static function bar($event)
 {
 dump($event);
 }
}

$trigger->on('database.table', 'write', 'Foo@bar'); // call default method 'handle'
$trigger->on('database.table', 'write', ['Foo', 'bar']);

action as job

Job

namespace App\Jobs;

class ExampleJob extends Job
{
 private $event;

 public function __construct($event)
 {
 $this->event = $event;
 }

 public function handle()
 {
 dump($this->event);
 }
}

Route

$trigger->on('database.table', 'write', 'App\Jobs\ExampleJob'); // call default method 'dispatch'
$trigger->on('database.table', 'write', 'App\Jobs\ExampleJob@dispatch_now');

Event List

php artisan trigger:list [-R=xxx]

Terminate

php artisan trigger:terminate [-R=xxx]

Thanks to

JetBrains