mccomaschris / thundr-cli
Thundr CLI for managing Laravel and Statamic sites.
Installs: 0
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:project
Requires
- php: ^8.2
- laravel/prompts: ^0.3.5
- symfony/console: ^6.0
- symfony/process: ^6.0
- symfony/yaml: ^6.0
Requires (Dev)
- laravel/pint: ^1.21
- mockery/mockery: ^1.6
- pestphp/pest: ^2.36
- phpstan/phpstan: ^2.1
README
Thundr is a PHP CLI tool for managing Laravel and Statamic sites on your servers—without SSHing in manually. It helps you provision, deploy, configure, and maintain sites using a simple thundr.yml
file.
Features
- 🔧 Site provisioning with PHP, Nginx, and MySQL
- 🔐 SSL via Let's Encrypt or Cloudflare Origin Certificates
- ⚙️ Cron/scheduler management
- 📦 Zero-downtime deployments
- 🛠 Remote
.env
, logs, and Artisan command execution - 📂 Multiple server support with centralized config
- 🧼 Rollback and release pruning
Requirements
- PHP 8.1+
- Laravel or Statamic project
thundr.yml
file in your project root- Remote server with SSH access and a
thundr
user
Installation
composer global require mccomaschris/thundr-cli
Make sure Composer's global vendor/bin directory is in your $PATH.
Quick Start
- Initialize global config:
thundr config:init
- Set up your project:
thundr site:init
- Provision the site on the server:
thundr site:create
- Deploy it:
thundr site:deploy
Example thundr.yml
root_domain: example.com repo: user/repo.git branch: main php_version: '8.3' project_type: laravel server: my-production-server operating_system: ubuntu
Full Command Reference
We’ve documented each command with descriptions, usage examples, and notes:
Contributing
Pull requests and suggestions are welcome! Please open an issue or submit a PR.
License
MIT