Skip to content

Laravel projects deploy made easy and fast using Envoy task runner and this script.

License

Notifications You must be signed in to change notification settings

arsamme/Laravel-Auto-Deploy-Envoy-Script

Folders and files

NameName
Last commit message
Last commit date

Latest commit

fc1b7f9 · Jan 24, 2021

History

15 Commits
Jan 22, 2021
Jan 24, 2021
Jan 24, 2021
Jan 24, 2021

Repository files navigation

Laravel Auto Deploy Envoy Script

Laravel projects deploy made easy and fast using Envoy task runner and this script. Inspired by sajadabasi/auto-deploy-scripts.

  • This script will provide a zero-downtime deployment.
  • Safe to run. All changes will revert if script fails.
  • Notifications. You can set services like Telegram, Slack and Discord webhooks to get notification when deploy finishes.
  • You can config and change almost everything.
  • Prints how much deploy took time.
  • Very easy to use. Start deploy just with one command.

How to use

Install Envoy

Documentation for Envoy can be found on the Laravel website.

Add Files

Add deploy.env and envoy.blade.php to your Laravel project's root.

Run

Run deploy script using this command :

envoy run deploy

Config Variables

You can change config variables in deploy.env file.

Variable Required Description Type Default Example
GIT_REPOSITORY YES Project's git repository address String https://github.com/arsamme/my-laravel-project.git
GIT_BRANCH NO Branch that project will be cloned from String master develop
DEPLOY_SERVER YES Deployment server String [email protected]
DEPLOY_PATH YES Path in server to clone project inside String /home/arsam/web/arsam.me/
DEPLOY_DESTINATION_PATH YES Path which will linked to public path of project String /home/arsam/web/arsam.me/public_html/
DEPLOY_STORAGE_PATH YES Path which storage folder moved to String /home/arsam/web/arsam.me/storage/
USER NO This will used to define which user owns project's folder in server String root admin
USER_GROUP NO This will used to define which user group owns project's folder in server String root admin
COMPOSER_INSTALL NO Set whether to run composer install or not Boolean true
CREATE_ENV_FILE NO Set whether to create new .env file from .env.prod or .env.example or not Boolean true
GENERATE_APPLICATION_KEY NO Set whether to generate application key using artisan command or not Boolean true
NPM_INSTALL NO Set whether to run npm install or not Boolean true
NPM_RUN_PROD NO Set whether to run npm run prod or not Boolean true
DATABASE_MIGRATION NO Set whether to run database migrations or not Boolean false
DATABASE_SEED NO Set whether to run database seeders or not Boolean false
STORAGE_SYMLINK NO Set whether to create storage symlink in public folder or not, this uses artisan command Boolean true
CONFIG_CACHE NO Set whether to run artisan cache commands or not Boolean true
EXTRA_BASH_SCRIPT NO Extra bash script to run at end of deploy, inside deploy path String ls -la
BACKUP_OLD_BUILD NO Set whether to save backup of old build or not Boolean false
TELEGRAM_BOT_API_TOKEN NO Telegram bot api token used to send notifiation on task finish String false 1248907810:AAFVU6ubAVjdasdac3uIwf8s8WGHPKSL4
TELEGRAM_CHAT_ID NO Telegram chat id for sending finished ntification to. Can be channel username of chat id. String false @arsamme
DISCORD_WEBHOOK_URL NO Discord webhook url to send finished notification. Boolean false
SLACK_WEBHOOK_URL NO Slack webhook url t send finished notification. Boolean false
SLACK_CHANNEL NO Define which channel you want to receive notifications in stock. Boolean false

About

Laravel projects deploy made easy and fast using Envoy task runner and this script.

Topics

Resources

License

Stars

Watchers

Forks