sansanlabs / laravel-git-ftp-deployer
Laravel Git-FTP deployment package with git status checking and build integration
Fund package maintenance!
sansanlabs
Requires
- php: ^8.2
- illuminate/contracts: ^10.0||^11.0||^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- larastan/larastan: ^2.9||^3.0
- laravel/pint: ^1.14
- nunomaduro/collision: ^8.1.1||^7.10.0
- orchestra/testbench: ^10.0.0||^9.0.0||^8.22.0
- pestphp/pest: ^3.0
- pestphp/pest-plugin-arch: ^3.0
- pestphp/pest-plugin-laravel: ^3.0
- phpstan/extension-installer: ^1.3||^2.0
- phpstan/phpstan-deprecation-rules: ^1.1||^2.0
- phpstan/phpstan-phpunit: ^1.3||^2.0
- spatie/laravel-ray: ^1.35
README
A Laravel package for deploying applications via FTP with git status checking and build process integration.
Features
- ✅ Check git status before deployment
- ✅ Prevent deployment with uncommitted changes
- ✅ Prevent deployment with unpushed commits
- ✅ Run build commands (npm, yarn, etc.) before deployment
- ✅ Support multiple environments (staging, production)
- ✅ Beautiful tree view for uncommitted changes
- ✅ Cross-platform support (Windows, Linux, macOS)
- ✅ Configurable git-ftp options
Requirements
- PHP ^8.2
- Laravel ^10.0|^11.0|^12.0
- git-ftp installed on your system
Installation
You can install the package via composer:
composer require sansanlabs/laravel-git-ftp-deployer
You can publish the config file with:
php artisan vendor:publish --tag="git-ftp-deployer-config"
This is the contents of the published config file:
return [ /* |-------------------------------------------------------------------------- | Git-FTP Deploy Configuration |-------------------------------------------------------------------------- | | Configuration for Git-FTP deployment package | */ "environments" => [ "staging" => [ "host" => env("STAGING_FTP_HOST"), "username" => env("STAGING_FTP_USERNAME"), "password" => env("STAGING_FTP_PASSWORD"), "path" => env("STAGING_FTP_PATH", "/website/"), ], "production" => [ "host" => env("PRODUCTION_FTP_HOST"), "username" => env("PRODUCTION_FTP_USERNAME"), "password" => env("PRODUCTION_FTP_PASSWORD"), "path" => env("PRODUCTION_FTP_PATH", "/website/"), ], ], /* |-------------------------------------------------------------------------- | Build Command |-------------------------------------------------------------------------- | | The command to run before deployment | */ "build_command" => env("GIT_FTP_BUILD_COMMAND", "npm run build"), /* |-------------------------------------------------------------------------- | Git Bash Path |-------------------------------------------------------------------------- | | Path to Git Bash executable (default on Windows) | */ "git_bash_path" => env("GIT_BASH_PATH", "C:\\Program Files\\Git\\bin\\bash.exe"), /* |-------------------------------------------------------------------------- | Git-FTP Options |-------------------------------------------------------------------------- | | Additional options for git-ftp command | */ "git_ftp_options" => [ "force" => env("GIT_FTP_FORCE", true), "verbose" => env("GIT_FTP_VERBOSE", true), "auto_init" => env("GIT_FTP_AUTO_INIT", true), ], ];
Configuration
Add your FTP credentials to your .env file:
# Staging Environment STAGING_FTP_HOST=ftp.yoursite.com STAGING_FTP_USERNAME=your-username STAGING_FTP_PASSWORD=your-password STAGING_FTP_PATH=/public_html/staging/ # Production Environment PROD_FTP_HOST=ftp.yoursite.com PROD_FTP_USERNAME=your-username PROD_FTP_PASSWORD=your-password PROD_FTP_PATH=/public_html/ # Build Command (optional) FTP_BUILD_COMMAND="npm run build" # Git Bash Path GIT_BASH_PATH="C:\Program Files\Git\bin\bash.exe"
Usage
Basic Deployment
Deploy to staging:
php artisan deploy:ftp --env=staging
Deploy to production:
php artisan deploy:ftp --env=production
Interactive environment selection:
php artisan deploy:ftp
Skip Build Process
Skip the build command:
php artisan deploy:ftp --skip-build
Configuration Options
The package configuration file config/ftp-deploy.php allows you to customize:
- Environments: Define multiple deployment environments
- Build Command: Command to run before deployment (default: npm run build)
- Git Bash Path: Path to Git Bash executable (Windows only)
- Git FTP Options: Additional options for git-ftp command
Git Status Checking
The package will check for:
- Uncommitted Changes: Files that have been modified but not committed
- Unpushed Commits: Commits that exist locally but haven't been pushed to origin
If either condition is found, deployment will be aborted with a detailed report.
Build Process
Before deployment, the package will run your configured build command (default: npm run build). This ensures your assets are compiled and ready for production.
FTP Deployment
The package uses git-ftp to efficiently deploy only changed files to your FTP server. It supports:
- Force push
- Verbose output
- Auto-initialization of git-ftp
- Custom sync roots and paths
Testing
Upcoming ...
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.