codegreencreative / laravel-heroku-deploy
Set up post deploy and pr pre destroy scripts for your Heroku review apps.
Requires
- php: ^7.3
- guzzlehttp/guzzle: ^7.4.4
- illuminate/routing: ^7|^8
- illuminate/support: ^7|^8
Requires (Dev)
- orchestra/testbench: ^5.0
- phpunit/phpunit: ^8.5|^9.0
This package is auto-updated.
Last update: 2024-11-10 18:19:27 UTC
README
Laravel Heroku Deploy
This Laravel 7+ package allows you to configure your Heroku Review Apps instance for Laravel applications. You can manage custom domains using Cloudflare, apply Automated Certificate Management (ACM) with Lets Encrypt and update Config Vars using Heroku's postdeploy
and pr-predestroy
script events.
Installation
Require this package with composer:
composer require codegreencreative/laravel-heroku-deploy
Configuration
The command below will add a new heroku-deploy.php config file in your config folder.
php artisan vendor:publish --tag="heroky_deploy_config"
heroku-deploy.php
Sample heroku-deploy configuration file.
// config/heroku-deploy.php return [ // Heroku Platform API token, learn more here: // https://devcenter.heroku.com/articles/authentication 'heroku_token' => env('HEROKU_DEPLOY_HEROKU_TOKEN', null), // Cloudflare token, get yours here: // https://dash.cloudflare.com/profile/api-tokens 'cloudflare_token' => env('HEROKU_DEPLOY_CLOUDFLARE_TOKEN', null), // Created by Heroku, just capture the information 'app_name' => env('HEROKU_APP_NAME', null), 'pr_number' => env('HEROKU_PR_NUMBER', null), // JSON array containing information on your zones you want to use for this project // { // "mydomain.com": ["id", "account", "support", "policies"] // } 'cloudflare_zones' => json_decode(env('HEROKU_DEPLOY_ZONES', '[]'), true), // You can attach addons from other applications // { // "addon_id": "confirming_app (id or name)" // } 'heroku_addon_attachments' => json_decode(env('HEROKU_DEPLOY_ADDON_ATTACHMENTS', '[]'), true), // Enable automated certificate management in Heroku for each subdomain 'enable_acm' => env('HEROKU_DEPLOY_ENABLE_ACM', true) ];
.env
Example .env entry.
HEROKU_DEPLOY_HEROKU_TOKEN=addyourtokenehere
HEROKU_DEPLOY_CLOUDFLARE_TOKEN=addyourtokenehere
HEROKU_DEPLOY_ZONES="{\"mydomain.com\": [\"id\", \"account\", \"support\"]}"
# Optional
# This connects Heroku Postgres database or Heroku Redis, for example
HEROKU_DEPLOY_ADDON_ATTACHMENTS="{\"xxxx-xxxx-xxxx-xxxx-xxxx\": \"xxxxxxxxx\"}"
HEROKU_DEPLOY_ENABLE_ACM=false
app.json
Add the postdeploy
and pr-predestroy
commands to your app.json file.
{ "environments": { "review": { "scripts": { "postdeploy": "php artisan heroku:postdeploy", "pr-predestroy": "php artisan heroku:pr-predestroy" } } } }
Config Vars
Two additional config vars are added/updated depending on your own configuration, APP_BASE_DOMAIN
and APP_URL
. The first domain you define in HEROKU_DEPLOY_ZONES
will be considered your base/primary domain as you can only have one. The first subdomain of your first domain is considered your APP_URL
. We also use the pull request number to keep review apps unique. Pull request numbers are provided by Heroku as environment variables.
For example, these will be added to your environment automatically:
APP_BASE_DOMAIN=pr-125.mydomain.com
APP_URL=https://id.pr-125.mydomain.com
Should you not enable ACM, session cookies will be set to insecure.
SESSION_SECURE_COOKIE=false
Session cookies will be created with a unique name.
SESSION_COOKIE=PR125_SID
Any other config vars that need to be added can be done so in your Heroku pipeline.
Bug Reporting
If Bugsnag is installed, exceptions will be reported in Bugsnag.
Todo
- Check logging config for errorlog | bugsnag
- Redirect default herokuapp.com subdomain to root domain