thundrlabs / thundr-cli
Thundr CLI for managing Laravel and Statamic sites.
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/thundrlabs/thundr-cli
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, MySQL, Redis, and more
- 🔐 SSL via Let's Encrypt or Cloudflare Origin Certificates
- ⚙️ Scheduler and cron management
- 📦 Zero-downtime deployments with shared .env, releases, and rollbacks
- 🛠 Remote .env, logs, and Artisan command execution
- 📂 Multiple server support with centralized global config
- 🧼 Rollback support and automatic release pruning
Requirements
- PHP 8.1+
- Laravel or Statamic project
- thundr.ymlfile in your project root
- Remote server with SSH access (thundruser will be provisioned)
Installation
composer global require thundrlabs/thundr-cli
Make sure Composer's global vendor/bin directory is in your $PATH.
Quick Start
It's best to start with a clean install of Ubuntu 24.04 or Oracle Linux 9.
- 
Initialize global config: thundr config:init 
- 
Provision the server (installs PHP, Nginx, MySQL, Redis, Node via NVM, etc.): thundr server:provision 
- 
Set up your project: thundr site:init 
- 
Provision the site on the server: thundr site:create 
- 
Deploy the project: thundr site:deploy 
Example thundr.yml
production: 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