Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
The envalid npm package is a library for validating and accessing environment variables in Node.js applications. It helps ensure that your environment variables are present and correctly formatted, reducing the risk of runtime errors due to misconfiguration.
Environment Variable Validation
This feature allows you to define and validate environment variables with specific types and constraints. The `cleanEnv` function ensures that the environment variables are present and correctly formatted, providing default values if necessary.
const envalid = require('envalid');
const { str, num, bool } = envalid;
const env = envalid.cleanEnv(process.env, {
NODE_ENV: str({ choices: ['development', 'production', 'test'] }),
PORT: num({ default: 3000 }),
DEBUG: bool({ default: false })
});
console.log(env.NODE_ENV); // 'development', 'production', or 'test'
console.log(env.PORT); // 3000 if not specified
console.log(env.DEBUG); // false if not specified
Custom Validators
Envalid allows you to create custom validators for environment variables using the `makeValidator` function. This is useful for more complex validation logic that isn't covered by the built-in validators.
const envalid = require('envalid');
const { makeValidator } = envalid;
const myCustomValidator = makeValidator(x => {
if (x !== 'foo' && x !== 'bar') throw new Error('Must be either foo or bar');
return x;
});
const env = envalid.cleanEnv(process.env, {
MY_VAR: myCustomValidator()
});
console.log(env.MY_VAR); // 'foo' or 'bar'
Type Coercion
Envalid automatically coerces environment variables to the specified types. This ensures that your application receives the correct data types, reducing the need for manual type conversion.
const envalid = require('envalid');
const { str, num, bool } = envalid;
const env = envalid.cleanEnv(process.env, {
MY_STRING: str(),
MY_NUMBER: num(),
MY_BOOLEAN: bool()
});
console.log(typeof env.MY_STRING); // 'string'
console.log(typeof env.MY_NUMBER); // 'number'
console.log(typeof env.MY_BOOLEAN); // 'boolean'
Dotenv is a zero-dependency module that loads environment variables from a .env file into process.env. While it doesn't provide validation or type coercion like envalid, it is widely used for managing environment variables in Node.js applications.
Joi is a powerful schema description language and data validator for JavaScript. It can be used to validate environment variables, but it requires more setup compared to envalid. Joi is more flexible and can be used for validating other types of data as well.
Convict is a configuration management tool for Node.js that allows you to define a schema for your configuration, including environment variables. It provides validation and default values, similar to envalid, but also supports nested configurations and more complex use cases.
Envalid is a small library for validating and accessing
environment variables in Node.js programs
Envalid is a small library for validating and accessing environment variables in Node.js programs, aiming to:
envalid.cleanEnv(environment, validators, options)
cleanEnv()
returns a sanitized, immutable environment object, and accepts three
positional arguments:
environment
- An object containing your env vars (eg. process.env
)validators
- An object that specifies the format of required vars.options
- An (optional) object, which supports the following key:
reporter
- Pass in a function to override the default error handling and
console output. See src/reporter.ts
for the default implementation.By default, cleanEnv()
will log an error message and exit (in Node) or throw (in browser) if any required
env vars are missing or invalid. You can override this behavior by writing your own reporter.
import { cleanEnv, str, email, json } from 'envalid'
const env = cleanEnv(process.env, {
API_KEY: str(),
ADMIN_EMAIL: email({ default: 'admin@example.com' }),
EMAIL_CONFIG_JSON: json({ desc: 'Additional email parameters' }),
NODE_ENV: str({ choices: ['development', 'test', 'production', 'staging'] }),
})
// Read an environment variable, which is validated and cleaned during
// and/or filtering that you specified with cleanEnv().
env.ADMIN_EMAIL // -> 'admin@example.com'
// Envalid checks for NODE_ENV automatically, and provides the following
// shortcut (boolean) properties for checking its value:
env.isProduction // true if NODE_ENV === 'production'
env.isTest // true if NODE_ENV === 'test'
env.isDev // true if NODE_ENV === 'development'
For an example you can play with, clone this repo and see the example/
directory.
git clone https://github.com/af/envalid
cd envalid
yarn prepare
node example/server.js
Node's process.env
only stores strings, but sometimes you want to retrieve other types
(booleans, numbers), or validate that an env var is in a specific format (JSON,
URL, email address). To these ends, the following validation functions are available:
str()
- Passes string values through, will ensure a value is present unless a
default
value is given. Note that an empty string is considered a valid value -
if this is undesirable you can easily create your own validator (see below)bool()
- Parses env var strings "1", "0", "true", "false", "t", "f"
into booleansnum()
- Parses an env var (eg. "42", "0.23", "1e5"
) into a Numberemail()
- Ensures an env var is an email addresshost()
- Ensures an env var is either a domain name or an ip address (v4 or v6)port()
- Ensures an env var is a TCP port (1-65535)url()
- Ensures an env var is a URL with a protocol and hostnamejson()
- Parses an env var with JSON.parse
Each validation function accepts an (optional) object with the following attributes:
choices
- An Array that lists the admissible parsed values for the env var.default
- A fallback value, which will be present in the output if the env var wasn't specified.
Providing a default effectively makes the env var optional. Note that default
values are not passed through validation logic, they are default output values.devDefault
- A fallback value to use only when NODE_ENV
is explicitly set and not 'production'
.
This is handy for env vars that are required for production environments, but optional
for development and testing.desc
- A string that describes the env var.example
- An example value for the env var.docs
- A URL that leads to more detailed documentation about the env var.You can easily create your own validator functions with envalid.makeValidator()
. It takes
a function as its only parameter, and should either return a cleaned value, or throw if the
input is unacceptable:
import { makeValidator, cleanEnv } from 'envalid'
const twochars = makeValidator((x) => {
if (/^[A-Za-z]{2}$/.test(x)) return x.toUpperCase()
else throw new Error('Expected two letters')
})
const env = cleanEnv(process.env, {
INITIALS: twochars(),
})
You can use either one of makeValidator
, makeExactValidator
and makeStructuredValidator
depending on your use case.
makeValidator<BaseT>
This validator has the output narrowed down to a subtype of BaseT
(e.g. str
).
Example of a custom integer validator:
const int = makeValidator<number>((input: string) => {
const coerced = parseInt(input, 10)
if (Number.isNaN(coerced)) throw new EnvError(`Invalid integer input: "${input}"`)
return coerced
})
const MAX_RETRIES = int({ choices: [1, 2, 3, 4] })
// Narrows down output type to '1 | 2 | 3 | 4' which is a subtype of 'number'
makeExactValidator<T>
This validator has the output widened to T
(e.g. bool
). To understand the difference
with makeValidator
, let's use it in the same scenario:
const int = makeExactValidator<number>((input: string) => {
const coerced = parseInt(input, 10)
if (Number.isNaN(coerced)) throw new EnvError(`Invalid integer input: "${input}"`)
return coerced
})
const MAX_RETRIES = int({ choices: [1, 2, 3, 4] })
// Output type is 'number'
As you can see in this instance, the output type is exactly number
, the parameter type of
makeExactValidator
. Also note that here, int
is not parametrizable.
By default, if any required environment variables are missing or have invalid
values, Envalid will log a message and call process.exit(1)
. You can override
this behavior by passing in your own function as options.reporter
. For example:
const env = cleanEnv(process.env, myValidators, {
reporter: ({ errors, env }) => {
emailSiteAdmins('Invalid env vars: ' + Object.keys(errors))
},
})
Additionally, Envalid exposes EnvError
and EnvMissingError
, which can be checked in case specific error handling is desired:
const env = cleanEnv(process.env, myValidators, {
reporter: ({ errors, env }) => {
for (const [envVar, err] of Object.entries(errors)) {
if (err instanceof envalid.EnvError) {
...
} else if (err instanceof envalid.EnvMissingError) {
...
} else {
...
}
}
}
})
In addition to cleanEnv()
, as of v7 there is a new customCleanEnv()
function,
which allows you to completely replace the processing that Envalid applies after applying
validations. You can use this custom escape hatch to transform the output however you wish.
envalid.customCleanEnv(environment, validators, applyMiddleware, options)
customCleanEnv()
uses the same API as cleanEnv()
, but with an additional applyMiddleware
argument required in the third position:
applyMiddleware
- A function that can modify the env object after it's
validated and cleaned. Envalid ships (and exports) its own default
middleware (see src/middleware.ts), which you can mix and match with your own
custom logic to get the behavior you desire.The testOnly
helper function is available for setting a default value for an env var only when NODE_ENV=test
. It is recommended to use this function along with devDefault
. For example:
const env = cleanEnv(process.env, {
SOME_VAR: envalid.str({ devDefault: testOnly('myTestValue') }),
})
For more context see this issue.
structuredClone()
on Envalid's validated output?Since by default Envalid's output is wrapped in a Proxy, structuredClone will not work on it. See #177.
dotenv is a very handy tool for loading env vars from
.env
files. It was previously used as a dependency of Envalid. To use them together, simply
call require('dotenv').config()
before you pass process.env
to your envalid.cleanEnv()
.
react-native-config can be useful for React Native projects for reading env vars from a .env
file
fastify-envalid is a wrapper for using Envalid within Fastify
nestjs-envalid is a wrapper for using Envalid with NestJS
nuxt-envalid is a wrapper for using Envalid with NuxtJS
FAQs
Validation for your environment variables
The npm package envalid receives a total of 170,415 weekly downloads. As such, envalid popularity was classified as popular.
We found that envalid demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.