thecodeholic / laravel-hostinger-deploy
Laravel package for automated Hostinger deployment with GitHub Actions support
Installs: 6
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/thecodeholic/laravel-hostinger-deploy
Requires
- php: ^8.2
- illuminate/console: ^11.0|^12.0
- illuminate/process: ^11.0|^12.0
- illuminate/support: ^11.0|^12.0
- symfony/console: ^7.0
Requires (Dev)
- orchestra/testbench: ^8.0|^9.0
- phpunit/phpunit: ^10.0
README
Deploy your Laravel application to Hostinger shared hosting with automated GitHub Actions support.
Installation
Install the package via Composer:
composer require thecodeholic/laravel-hostinger-deploy:^0.3 --dev
Or install the latest version:
composer require thecodeholic/laravel-hostinger-deploy --dev
Note: This package should be installed as a development dependency (
--dev) since it's only needed during deployment, not in production.
Required Environment Variables
Before using any deployment commands, add these to your .env file:
HOSTINGER_SSH_HOST=your-server-ip HOSTINGER_SSH_USERNAME=your-username HOSTINGER_SSH_PORT=22 HOSTINGER_SITE_DIR=your-website-folder GITHUB_API_TOKEN=your-github-token
SSH Authentication Setup
⚠️ Important: It is highly recommended to set up SSH public key authentication on your Hostinger server instead of using password authentication. Public key authentication is more secure and eliminates the need to enter passwords during deployments.
To set up SSH public key authentication:
- Generate an SSH key pair on your local machine:
ssh-keygen -t rsa -b 4096- Copy your public key to the server:
ssh-copy-id username@your-server-ip- Test the connection:
ssh username@your-server-ip(should connect without password prompt)Once configured, the deployment commands will use your SSH key automatically, making deployments seamless and secure.
Quick Start (All-in-One Command)
The easiest way to deploy and set up automated deployment:
php artisan hostinger:deploy-and-setup-cicd
What this command does:
- Deploys your Laravel application to Hostinger
- Sets up SSH keys on the server
- Automatically adds deploy key to GitHub repository via API
- Publishes GitHub Actions workflow file locally (
.github/workflows/hostinger-deploy.yml) - Configures GitHub secrets and variables via API
Command Options:
--fresh- Delete existing files and clone fresh repository--site-dir=- Override site directory from config--token=- GitHub Personal Access Token (overrides GITHUB_API_TOKEN from .env)--branch=- Branch to deploy (default: auto-detect)--php-version=- PHP version for workflow (default: 8.3)
Individual Commands
1. Manual Deployment Only
php artisan hostinger:deploy
What it does: Deploys your Laravel application to Hostinger server (composer install, migrations, storage link, etc.)
Command Options:
--fresh- Delete existing files and clone fresh repository--site-dir=- Override site directory from config--token=- GitHub Personal Access Token (optional, enables automatic deploy key management)--show-errors- Display detailed error messages with exit codes and command output
Note: If
GITHUB_API_TOKENis provided (via.envor--tokenoption), the command will automatically add deploy keys to your GitHub repository. Otherwise, you'll be prompted to add the deploy key manually.
2. Create GitHub Actions Workflow File
php artisan hostinger:publish-workflow
What it does: Creates .github/workflows/hostinger-deploy.yml file locally
Command Options:
--branch=- Branch to trigger deployment (default: auto-detect)--php-version=- PHP version for workflow (default: 8.3)
3. Setup Automated Deployment (Via GitHub API)
php artisan hostinger:setup-cicd
What it does: Publishes GitHub Actions workflow file locally and creates secrets automatically via GitHub API, and automatically adds deploy keys to your repository
Command Options:
--token=- GitHub Personal Access Token (overrides GITHUB_API_TOKEN from .env)--branch=- Branch to deploy (default: auto-detect)--php-version=- PHP version for workflow (default: 8.3)
GitHub Personal Access Token Permissions: Your GitHub Personal Access Token needs the following permissions:
- Administration → Read and write (for managing deploy keys for the repository)
- Metadata → Read-only (automatically selected, required for API access)
Note: The workflow file is published locally to .github/workflows/hostinger-deploy.yml. You'll need to review, commit, and push it manually. The command only uses the API to create secrets and deploy keys.
Environment Variables Summary
| Variable | Required For | Description |
|---|---|---|
HOSTINGER_SSH_HOST |
All commands | Hostinger server IP address |
HOSTINGER_SSH_USERNAME |
All commands | Hostinger SSH username |
HOSTINGER_SSH_PORT |
All commands | SSH port (default: 22) |
HOSTINGER_SITE_DIR |
All commands | Website folder name |
GITHUB_API_TOKEN |
Automated setup | GitHub Personal Access Token (requires Administration permission for deploy keys) |
Requirements
- PHP ^8.2
- Laravel ^11.0|^12.0
- SSH access to Hostinger server
- Git repository (GitHub recommended)
- PHP
exec()function must be enabled (required for executing SSH commands and process management)
Important: This package requires the PHP
exec()function to be available and enabled on your system. Theexec()function is used for executing SSH commands and managing deployment processes. Ifexec()is disabled in your PHP configuration, deployment operations will fail.
License
MIT