mrbohem / larasync
Laravel Database Sync with UI dashboard
Fund package maintenance!
MrBohem
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/mrbohem/larasync
Requires
- php: ^8.3
- illuminate/contracts: ^11.0||^12.0
- livewire/livewire: ^3.6
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.8
- orchestra/testbench: ^10.0.0||^9.0.0
- pestphp/pest: ^4.0
- pestphp/pest-plugin-arch: ^4.0
- pestphp/pest-plugin-laravel: ^4.0
README
Larasync is a Laravel package that lets you compare and sync data between two databases through a beautiful Livewire-powered web dashboard. Connect any combination of SQLite, MySQL, or PostgreSQL databases, see a side-by-side row-count comparison for every table, and sync individual tables or all tables at once โ right from your browser.
โจ Features
- ๐ Connect any two databases โ SQLite, MySQL, or PostgreSQL
- ๐ Side-by-side table comparison โ row counts, diff, and sync status at a glance
- ๐ One-click sync โ sync a single table or all tables sequentially
- โ๏ธ Bi-directional sync โ choose
DB1 โ DB2orDB2 โ DB1 - ๐ท๏ธ Auto-labeling โ databases are auto-detected as Local or Cloud
- ๐ซ Ignored tables โ exclude tables (e.g.
sessions,telescope_*) from comparison & sync - ๐ฅ๏ธ Beautiful Livewire dashboard โ real-time progress, logs, and status indicators
- โ๏ธ Zero config needed โ works out of the box with
.envvariables
๐ Requirements
- PHP โฅ 8.3
- Laravel 11.x or 12.x
- Livewire 3.6+
๐ Installation
1. Install the package via Composer
composer require mrbohem/larasync --dev
2. (Optional) Publish the config file
php artisan vendor:publish --tag="larasync-config"
This creates config/larasync.php where you configure your two database connections and ignored tables.
3. (Optional) Publish the views
If you want to customize the dashboard UI:
php artisan vendor:publish --tag="larasync-views"
โ๏ธ Configuration
After publishing, open config/larasync.php and configure your two databases. You can set values directly or use .env variables:
Config File
return [ 'db1' => [ 'driver' => env('LARASYNC_DB1_DRIVER', 'sqlite'), 'host' => env('LARASYNC_DB1_HOST'), 'port' => env('LARASYNC_DB1_PORT', '3306'), 'database' => env('LARASYNC_DB1_DATABASE'), 'username' => env('LARASYNC_DB1_USERNAME'), 'password' => env('LARASYNC_DB1_PASSWORD', ''), ], 'db2' => [ 'driver' => env('LARASYNC_DB2_DRIVER', 'mysql'), 'host' => env('LARASYNC_DB2_HOST'), 'port' => env('LARASYNC_DB2_PORT', '3306'), 'database' => env('LARASYNC_DB2_DATABASE'), 'username' => env('LARASYNC_DB2_USERNAME'), 'password' => env('LARASYNC_DB2_PASSWORD', ''), ], 'ignored_tables' => [ 'sessions', 'telescope_entries_tags', 'telescope_entries', 'telescope_monitoring', 'pulse_entries', 'pulse_values', 'pulse_aggregates', ], ];
.env Example
# โโ Database 1 (e.g. local SQLite) โโ LARASYNC_DB1_DRIVER=sqlite LARASYNC_DB1_DATABASE=database.sqlite # โโ Database 2 (e.g. remote MySQL) โโ LARASYNC_DB2_DRIVER=mysql LARASYNC_DB2_HOST=your-cloud-db-host.com LARASYNC_DB2_PORT=3306 LARASYNC_DB2_DATABASE=your_database LARASYNC_DB2_USERNAME=your_username LARASYNC_DB2_PASSWORD=your_password
Note: For SQLite, the
databasevalue is resolved relative to Laravel'sdatabase_path()(i.e. thedatabase/directory).
๐ฅ๏ธ Usage
Access the Dashboard
Once installed, visit the sync dashboard in your browser:
https://your-app.test/sync-db
The route is automatically registered by the package at /sync-db.
Dashboard Workflow
- Configure connections โ Enter or verify the credentials for DB1 and DB2 (pre-filled from config)
- Test connections โ Click the test button for each database to verify connectivity
- Compare โ Hit "Compare" to see a table-by-table row-count comparison
- Choose sync direction โ Select
DB1 โ DB2orDB2 โ DB1 - Sync โ Sync individual tables with one click, or use "Sync All" to sync every table sequentially
Supported Drivers
| Driver | Value | Notes |
|---|---|---|
| SQLite | sqlite |
Always treated as Local |
| MySQL | mysql |
Local or Cloud auto-detected |
| PostgreSQL | pgsql |
Local or Cloud auto-detected |
Ignoring Tables
Add table names to the ignored_tables array in config/larasync.php to exclude them from comparison and sync:
'ignored_tables' => [ 'sessions', 'telescope_entries', 'jobs', 'failed_jobs', // add your tables here... ],
โ ๏ธ Important Notes
- Sync is destructive โ Syncing a table will truncate the target table and replace all its data with the source table's data. Always back up your databases before syncing.
- Foreign key constraints are temporarily disabled during sync to avoid constraint violations.
- Large tables are synced in chunks of 500 rows for efficiency.
- The dashboard route (
/sync-db) uses thewebmiddleware by default. You may want to add authentication middleware in production โ see Protecting the Dashboard.
๐ Protecting the Dashboard
The /sync-db route uses only the web middleware by default. In production, you should protect it with authentication. You can do this by adding middleware in your app's route service provider or by overriding the package route:
// In routes/web.php use MrBohem\Larasync\Http\Livewire\SyncDashboard; Route::get('sync-db', SyncDashboard::class) ->middleware(['web', 'auth', 'admin']) // add your middleware ->name('larasync.dashboard');
๐งช Testing
composer test
๐ค Credits
๐ License
The MIT License (MIT). Please see License File for more information.