#env #dotenv #php #symfony

darkweb-dotenv

A library that eases configuration via .env environment files

1 unstable release

0.1.0-beta1 Aug 2, 2020

#1388 in Development tools

MIT license

23KB
321 lines

Dotenv component

The Dotenv component parses .env files to make environment variables stored in them accessible via std::env.

Installation

Add the dependency to your Cargo.toml:

[dependencies]
darkweb-dotenv = "^1.0"

Usage

Sensitive information and environment-dependent settings should be defined as environment variables (as recommended for twelve-factor applications). Using a .env file to store those environment variables eases development and CI management by keeping them in one "standard" place and agnostic of the technology stack you are using.

# .env
DB_USER=root
DB_PASS=pass

Load a .env file in your application via Dotenv::load():

use darkweb_dotenv::Dotenv;

let mut dotenv = Dotenv::new();
dotenv.load(".env").unwrap();

Access the values with std::env in your code:

let db_user = std::env::var("DB_USER").unwrap();

The load() method never overwrites existing environment variables. Use the overload() method if you need to overwrite them:

// ...
dotenv.overload(".env").unwrap();

As you're working with the Dotenv component you'll notice that you might want to have different files depending on the environment you're working in. Typically this happens for local development or Continuous Integration where you might want to have different files for your test and dev environments.

You can use Dotenv::load_env() to ease this process:

// ...
dotenv.load_env(".env", "APP_ENV", "dev").unwrap();

The Dotenv component will then look for the correct .env files to load. If the environment variable APP_ENV is defined, its value is used to load environment-specific files. If the variable is not defined, dev is assumed for APP_ENV.

The following files are loaded if they exist, the latter taking precedence over the former:

  • .env --> committed environment defaults
  • .env.local --> uncommitted file with local overrides
  • .env.{APP_ENV} --> committed environment-specific defaults
  • .env.{APP_ENV}.local --> uncommitted environment-specific local overrides

License

Dotenv is licensed under the MIT License - see the LICENSE file for details.

Dependencies

~2–3MB
~53K SLoC