1.0.0 • Published 11 years ago
env-reader v1.0.0
env-reader
Streaming environment variable reader
Accepts simple key=value data and passes it on after performing some basic filtering out of things like blank lines, comment lines and invalid env lines. Now also handles removing the 'export' keyword from the start of env var lines
Examples
Require the module
var env = require('env-reader')()
Listening for data events
env.on('data', function (envLine) {
//do something
})
Writing data
env.write('\n#comment line\ninvalid line\nvalid=line\n \n')
//only valid=line would be passed emitted, the rest would be disguarded
This module was built with the following type of input in mind:
#ENV config file
#environment definition
ENV=development
#database definition
DB_HOST=localhost
DB_USER=user
DB_PASS=password
DB_NAME=development
export EXPORTED_VAR=true
and will emit the following lines from such a file one after another:
ENV=development
DB_HOST=localhost
DB_USER=user
DB_PASS=password
DB_NAME=development
EXPORTED_VAR=true
if streamed the data in the following way:
fs.createReadStream('example.file').pipe(env)
If you were to send it all the data at once like:
var envFileString = "#ENV config file\n#environment definition\nENV=development\n\n" +
"#database definition\nDB_HOST=localhost\nDB_USER=user\nDB_PASS=password\n" +
"DB_NAME=development"
env.write(envFileString)
it would still break the string apart and emit the cleaned up env pieces 1 after another