GithubHelp home page GithubHelp logo

nsweeting / exenv Goto Github PK

View Code? Open in Web Editor NEW
37.0 1.0 0.0 39 KB

Exenv makes loading environment variables from external sources easy.

License: MIT License

Elixir 100.00%
elixir dotenv environment-variables env config secrets yaml yml

exenv's Introduction

Exenv

Build Status Exenv Version

Exenv provides an adapter-based solution to loading environment variables from external sources.

It comes with the following adapter:

  • Exenv.Adapters.Dotenv (load from .env files)

But has support from external adapters as well:

Installation

This package can be installed by adding exenv to your list of dependencies in mix.exs:

def deps do
  [
    {:exenv, "~> 0.3"}
  ]
end

Documentation

Please see HexDocs for additional documentation. This readme provides a brief overview, but it is recommended that the docs are used.

Getting Started

If all you want is to load a .env file on application start - then you're already done! Out of the box, Exenv is configured to start itself with the Exenv.Adapters.Dotenv adapter configured with sane defaults. This means autoloading on application start - with the .env file required to be within your projects root directory.

Configuration

If you need finer grained control of things, Exenv provides extensive config mechansims.

We can pass configuration options to Exenv from application config.

config :exenv, [
  adapters: [
    {Exenv.Adapters.Dotenv, [file: "path/to/.env"]}
  ]
]

You can also run Exenv via your own supervision tree. In this case, you must instruct Exenv not to start itself.

config :exenv, start_on_application: false

Which allows you to add Exenv to your own application.

defmodule MySupervisor do
  use Supervisor

  def start_link(opts) do
    Supervisor.start_link(__MODULE__, :ok, opts)
  end

  def init(:ok) do
    children = [
      {Exenv, [adapters: [{Exenv.Adapters.Dotenv, [file: "path/to/.env"]}]]}
    ]

    Supervisor.init(children, strategy: :one_for_one)
  end
end

Options passed to the child_spec/1 callback take precedence over any application config.

By default, all adapters will autoload their environment vars when Exenv starts up. You can override this behaviour on a per-adapter basis, by simply passing the autoload: false key within your adapter config.

[
  adapters: [
    {Exenv.Adapters.Dotenv, [autoload: false, file: "path/to/.env"]}
  ]
]

You must then manually load all env vars from your defined adapters:

Exenv.load()

Runtime path evaluation

Any location where you pass a file path you can choose to instead pass an mfa which will be run and should evaluate to a proper file path. This allows for easier runtime setup of files.

config :exenv, [
  adapters: [
    {Exenv.Adapters.Dotenv, [file: {MyApp, :get_dotenv, []}]}
  ]
]

Encryption

Exenv has secrets encryption out of the box. Support will depend on the whether the adapter provides it. Using secrets encryption allows you to keep an encrypted version of your secrets checked into your repository. As long as the master key is accessible, these secrets can then be decrypted.

To get started with secrets encryption, first generate a master key.

mix exenv.master_key /config/master.key

This will generate a new master key at /config/master.key. You can then encrypt your secrets file.

mix exenv.encrypt /config/master.key /config/.env

This will encrypt the contents of /config/.env using /config/master.key. A new file will then be generated at /config/.env.enc with your encrypted secrets.

You must then provide the proper options to your adapters to enable encryption.

{Exenv.Adapters.Dotenv, [file: "path/to/.env.enc", encryption: true]}

The above will attempt to decrypt "path/to/.env.enc" using the contents of the "MASTER_KEY" env var. Alternatively, you can also provide a direct path to the master key file.

{Exenv.Adapters.Dotenv, [file: "path/to/.env.enc", encryption: [master_key: "path/to/master.key"]]}

To edit your secrets, you just need to decrypt the original encrypted secrets, and rencrypt the edited file.

mix exenv.decrypt /config/master.key /config/.env.enc

## Add to file

mix exenv.encrypt /config/master.key /config/.env

exenv's People

Contributors

nsweeting avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar

exenv's Issues

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.