@specialblend/env
TypeScript icon, indicating that this package has built-in type declarations

0.0.11 • Public • Published

@specialblend/env

compile- & runtime- safe, "monadic" node process.env parser utility for javascript and typescript

install

npm install @specialblend/env

usage

#!/usr/bin/env node-ts

/* eslint-disable new-cap,no-inline-comments */

import env, { BooleanParameter, InvalidParameterException, NumericParameter, StringParameter } from '@specialblend/env';

(async function main() {

// define your environment schema as a TypeScript interface
interface EnvSchema {
    EXAMPLE_AWS_ACCESS_KEY_ID: string;
    EXAMPLE_AWS_SECRET_ACCESS_KEY: string;
    EXAMPLE_TIMEOUT: number;
}

const schema = {
    EXAMPLE_AWS_ACCESS_KEY_ID: StringParameter('EXAMPLE_AWS_ACCESS_KEY_ID', 'DEFAULT_EXAMPLE_AWS_ACCESS_KEY_ID'),
    EXAMPLE_AWS_SECRET_ACCESS_KEY: StringParameter('EXAMPLE_AWS_ACCESS_KEY_ID'),
    EXAMPLE_CACHE_TIMEOUT: NumericParameter('EXAMPLE_CACHE_TIMEOUT', 1234),
    EXAMPLE_CACHE_ENABLED: BooleanParameter('EXAMPLE_CACHE_ENABLED', false),
};

// eslint-disable-next-line no-process-env
const myEnv = env<EnvSchema>(process.env, schema);

// typescript definitions enable autocomplete of myEnv[<keyof EnvSchema>]
console.log(await myEnv.EXAMPLE_AWS_ACCESS_KEY_ID); // => process.env.EXAMPLE_AWS_ACCESS_KEY_ID or 'DEFAULT_EXAMPLE_AWS_ACCESS_KEY_ID'
console.log(await myEnv.EXAMPLE_AWS_SECRET_ACCESS_KEY); // => process.env.EXAMPLE_AWS_SECRET_ACCESS_KEY or throws {InvalidParameterException}
console.log(await myEnv.EXAMPLE_CACHE_TIMEOUT); // => process.env.EXAMPLE_CACHE_TIMEOUT or `1234`
console.log(await myEnv.EXAMPLE_CACHE_ENABLED); // => process.env.EXAMPLE_CACHE_ENABLED as boolean or `false`

}()).catch(console.log);

Readme

Keywords

none

Package Sidebar

Install

npm i @specialblend/env

Weekly Downloads

0

Version

0.0.11

License

ISC

Unpacked Size

10.7 kB

Total Files

5

Last publish

Collaborators

  • __specialblend__