brainstud / laravel-deployment-scripts
Create one time deployment scripts to run at the next release
Installs: 4 118
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 2
Open Issues: 0
Requires
- php: ^8.2
- illuminate/contracts: ^8.73|^9|^10|^11
- illuminate/database: ^8.77|^9|^10|^11
- spatie/laravel-package-tools: ^1.9.2
Requires (Dev)
- nunomaduro/collision: ^5.10
- nunomaduro/larastan: ^1.0
- orchestra/testbench: ^6.22
- pestphp/pest: ^1.21
- pestphp/pest-plugin-laravel: ^1.1
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.5|^10.0
- spatie/laravel-ray: ^1.26
This package is auto-updated.
Last update: 2025-01-04 14:07:32 UTC
README
When deploying new code you'll sometimes need to execute one time scripts, commands or queries to activate new functionalities. With a growing application, it is easy to lose sight of which things should be executed for a given deployment. Laravel already has migrations which run after executing the artisan migrate command, but these migrations are aimed at database operations only.
The Laravel one time deployment scripts package aims to solve this problem by offering a migration-like way of registering scripts, commands and queries that should be executed. By simply registering the deployment scripts execute command, the package will check whether there are any scripts that should be executed. Once a script has been executed it will be registered in the database so that it won't run again.
Example
The code snippet below is an example of how the deployment script is configured. A regular or an anonymous class is created which extends the DeploymentScript base class. Then it registers the up and down methods to contain the deployment tasks that need to be executed, and finally within those methods the desired tasks are executed.
return new class extends DeploymentScript { public function up() { $this->command('mycommand:trigger'); $this->query('UPDATE `table` SET `foo` = 1 WHERE `baz` IS NULL'); } public function down() { $this->closure(function () { (new CustomActionClass())->execute(); }); } }
Installation
You can install the package via composer:
composer require brainstud/laravel-deployment-scripts
You can publish and run the migrations with:
php artisan vendor:publish --tag="deployment-scripts-migrations"
php artisan migrate
You can publish the config file with:
php artisan vendor:publish --tag="deployment-scripts-config"
This is the content of the published config file:
return [ 'table_name' => 'deployment_scripts_log', ];
Usage
Available commands
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
License
The MIT License (MIT). Please see License File for more information.