Package to manage database backups in a Laravel project. Easily integrates with Dropbox and AWS S3.
skcin7/laravel-backups is a Laravel package for package to manage database backups in a laravel project. easily integrates with dropbox and aws s3..
It currently has 1 GitHub stars and 18 downloads on Packagist.
Install it with composer require skcin7/laravel-backups.
Discover more Laravel packages by skcin7
or browse all Laravel packages to compare alternatives.
Last updated
Package to manage database backups in a Laravel project. Easily integrates with Dropbox and AWS S3.
This package is based on wladmonax/laravel-db-backup so credit to them for their great work.
Run Composer command: composer require skcin7/laravel-backups
Copy the config file into your project by running
php artisan vendor:publish
This will generate a config file like this
return [
// add a backup folder in the app/database/ or your dump folder
'path' => app_path() . '/database/backup/',
// add the path to the restore and backup command of mysql
// this exemple is if your are using MAMP server on a mac
// on windows: 'C:\\...\\mysql\\bin\\'
// on linux: '/usr/bin/'
// trailing slash is required
'mysql' => [
'dump_command_path' => '/Applications/MAMP/Library/bin/',
'restore_command_path' => '/Applications/MAMP/Library/bin/',
],
// s3 settings
's3' => [
'path' => 'your/s3/dump/folder'
]
//dropbox settings
'dropbox' => [
'accessToken' => DROPBOX_ACCESS_TOKEN,
'appSecret' => DROPBOX_APP_SECRET,
'prefix' => DROPBOX_PREFIX, //this is name of your dropbox folder
],
//encrypt settings
'encrypt' => [
'key' => ENCRYPT_KEY
],
// Use GZIP compression
'compress' => false,
];
All settings are optional and have reasonable default values.
Creates a dump file in app/storage/dumps
$ php artisan db:backup
$ php artisan db:backup --database=mysql
$ php artisan db:backup --encrypt
$ php artisan db:backup --dropbox
$ php artisan db:backup --dropbox --encrypt
$ php artisan db:backup --upload-s3 your-bucket
You can use the --keep-only-s3 option if you don't want to keep a local copy of the SQL dump.
Uses the aws/aws-sdk-php-laravel package which needs to be configured.
Uses the spatie/flysystem-dropbox package.
Paths are relative to the app/storage/dumps folder.
$ php artisan db:restore dump.sql
$ php artisan db:restore --last-dump
$ php artisan db:restore --dropbox-dump=filename.sql
$ php artisan db:restore --dropbox-last-dump
$ php artisan db:restore