Works with [dotenv-vault](https://github.com/dotenv-org/dotenv-vault). Learn more at [dotenv.org/vault](https://dotenv.org/vault?r=1).
# dotenv
Dotenv is a zero-dependency module that loads environment variables from a `.env` file into [`process.env`](https://nodejs.org/docs/latest/api/process.html#process_process_env). Storing configuration in the environment separate from code is based on [The Twelve-Factor App](http://12factor.net/config) methodology.
[data:image/s3,"s3://crabby-images/98fec/98fecc112f249ad3d7940ab7cfebf723f39f7545" alt="BuildStatus"](https://travis-ci.org/motdotla/dotenv)
[data:image/s3,"s3://crabby-images/898a0/898a0fcb26426dfa2c9dfff16841de2ec731dbad" alt="Build status"](https://ci.appveyor.com/project/motdotla/dotenv/branch/master)
[data:image/s3,"s3://crabby-images/edcc6/edcc62867fa3df2d90e3c90cecb2990ed586ce22" alt="NPM version"](https://www.npmjs.com/package/dotenv)
[data:image/s3,"s3://crabby-images/b35e6/b35e6c4f18cd54461b2346dca45c0bb4494e905e" alt="js-standard-style"](https://github.com/feross/standard)
[data:image/s3,"s3://crabby-images/5dcf0/5dcf0f07fbaaa071472e9d48a9126f70f3bf3070" alt="Coverage Status"](https://coveralls.io/github/motdotla/dotenv?branch=coverall-intergration)
[data:image/s3,"s3://crabby-images/e838c/e838ce4c4b60f13e710ae53ebb56c9bc5b42afbe" alt="LICENSE"](LICENSE)
[data:image/s3,"s3://crabby-images/347ca/347ca9f386c866cfbeab45f682d733f7854a18ea" alt="Conventional Commits"](https://conventionalcommits.org)
[data:image/s3,"s3://crabby-images/a38ec/a38ec9ed67d6882ecab9d04b3a2dcc82568f2352" alt="Rate on Openbase"](https://openbase.com/js/dotenv)
## Install
```bash
# install locally (recommended)
npm install dotenv --save
```
Or installing with yarn? `yarn add dotenv`
## Usage
Create a `.env` file in the root of your project:
```dosini
S3_BUCKET="YOURS3BUCKET"
SECRET_KEY="YOURSECRETKEYGOESHERE"
```
As early as possible in your application, import and configure dotenv:
```javascript
require('dotenv').config()
console.log(process.env) // remove this after you've confirmed it working
```
.. or using ES6?
```javascript
import 'dotenv/config' // see https://github.com/motdotla/dotenv#how-do-i-use-dotenv-with-import
import express from 'express'
```
That's it. `process.env` now has the keys and values you defined in your `.env` file:
```javascript
require('dotenv').config()
...
s3.getBucketCors({Bucket: process.env.S3_BUCKET}, function(err, data) {})
```
### Multiline values
If you need multiline variables, for example private keys, those are now supported (`>= v15.0.0`) with line breaks:
```dosini
PRIVATE_KEY="-----BEGIN RSA PRIVATE KEY-----
...
Kh9NV...
...
-----END DSA PRIVATE KEY-----"
```
Alternatively, you can double quote strings and use the `\n` character:
```dosini
PRIVATE_KEY="-----BEGIN RSA PRIVATE KEY-----\nKh9NV...\n-----END DSA PRIVATE KEY-----\n"
```
### Comments
Comments may be added to your file on their own line or inline:
```dosini
# This is a comment
SECRET_KEY=YOURSECRETKEYGOESHERE # comment
SECRET_HASH="something-with-a-#-hash"
```
Comments begin where a `#` exists, so if your value contains a `#` please wrap it in quotes. This is a breaking change from `>= v15.0.0` and on.
### Parsing
The engine which parses the contents of your file containing environment variables is available to use. It accepts a String or Buffer and will return an Object with the parsed keys and values.
```javascript
const dotenv = require('dotenv')
const buf = Buffer.from('BASIC=basic')
const config = dotenv.parse(buf) // will return an object
console.log(typeof config, config) // object { BASIC : 'basic' }
```
### Preload
You can use the `--require` (`-r`) [command line option](https://nodejs.org/api/cli.html#-r---require-module) to preload dotenv. By doing this, you do not need to require and load dotenv in your application code.
```bash
$ node -r dotenv/config your_script.js
```
The configuration options below are supported as command line arguments in the format `dotenv_config_