Skip to content

jplethier/capistrano-dotenv

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

22 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Gem Version Dependencies Code Climate

Capistrano::Dotenv

Capitranos tasks to setup and check env vars using dotenv

Installation

Add this line to your application's Gemfile:

gem 'capistrano-dotenv', require: false

And then execute:

$ bundle

Or install it yourself as:

$ gem install capistrano-dotenv

Usage

Require in Capfile:

require 'capistrano/dotenv'

To check and ensure that deploy contains invoke both dotenv:read and dotenv:check tasks before to invoke dotenv:setup

invoke 'dotenv:read'
invoke 'dotenv:check'
invoke 'dotenv:setup'

If you do not want to check, invoke only dotenv:read and dotenv:setup to just read and upload the env vars

invoke 'dotenv:read'
invoke 'dotenv:setup'

If you want to auto prefix dotenv to yout bundle/ruby/gem/rake commands, add dotenv:hook to your invokes.

invoke 'dotenv:read'
invoke 'dotenv:check'
invoke 'dotenv:setup'
invoke 'dotenv:hook'

Options

Env file

Use differents env files for each environment

set :env_file, ".env_#{stage}"

Or use the same file for every environment(default)

set :env_file, '.env'

If you use dotgpg to secure your env vars on git, just set the env_file passing the gpg file, and it will ask your gpg password and read it from gpg file correctly. For example:

set :env_file, ".env_#{stage}.gpg"

Optional env vars

There are env vars that you want to set only in some enviroments or you will use a default value if it is not defined, so it is not required to be set a value for them. To be able to run check without fail the deployment if those env vars do not have a value set, just set it as optional

set :optional_env_vars, %w(OPTIONAL_VAR1 OPTIONAL_VAR2)

Ignored env vars

There are project env vars needed only for test or development environment, so those vars need to be ignored when you are deploying the project

set :ignored_env_vars, %w(IGNORED_VAR1 IGNORED_VAR2)

Roles

By default, the setup task will upload generated .env file to all roles(:all), but you can define what roles to run this

set :dotenv_roles, :app

Hook

By default, dotenv:hook will work on bundle, ruby, gem and rake. You can change this setting dotenv_hook_commands.

set :dotenv_hook_commands, %w(bundle ruby gem rake my_custom_command)

By default, dotenv:hook will add the dotenv prefix before the commands. You can change this setting dotenv_hook_prefix.

set :dotenv_hook_prefix, 'dotenv -f ".my_custom_env_file"'

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/jplethier/capistrano-dotenv.

License

The gem is available as open source under the terms of the MIT License.

About

Capistrano task to check env vars

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •  

Languages