typed-env
TypeScript icon, indicating that this package has built-in type declarations

2.0.0 • Public • Published

typed-env

npm version monthly downloads

A typed environment variable parser with support for choices, custom parsers, and more.

Usage

import { createEnv } from 'typed-env';

const env = createEnv({
  PORT: { type: 'number', default: 80 }
});

env.PORT; // number

Features

  • Strongly typed
  • Supports custom parsers
  • Supports optional environment variables
  • Supports limiting the possible values (see Choices)
  • Supports passing custom environments (see Options)

Choices

import { createEnv } from 'typed-env';

const env = createEnv({
  NODE_ENV: {
    type: 'string',
    choices: ['development', 'production']
  }
});

env.NODE_ENV; // 'development' | 'production'

Parser

You can pass a parser function to return your own custom type

import { createEnv } from 'typed-env';

const env = createEnv({
  HOMEPAGE: { parser: url => new URL(url) }
});

env.HOMEPAGE; // URL

Options

If you want to use a custom env, pass env in the options parameter, otherwise it will load from process.env

interface Options {
  env?: Record<string, string> | NodeJS.ProcessEnv;
}

Package Sidebar

Install

npm i typed-env

Weekly Downloads

2,591

Version

2.0.0

License

MIT

Unpacked Size

22.2 kB

Total Files

9

Last publish

Collaborators

  • lukeuke
  • superchupu