Skip to content

Latest commit

 

History

History

config

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 

@dot/config

A configuration contract for Node + AWS projects.

The contract that this package implements covers the following:

  • Error handling and assertion of configuration values. Empty or missing values stop execution.
  • Ease of access to environment variables
  • Ease of access to AWS SSM Parameters
  • Ease of access to AWS Secrets Manager secrets
  • No need to use or access process.env
  • Specify default values for configuration
  • Provide canonical environment names, centalize environment parsing

For TypeScript users, known configuration values are provided in intellisense based on the keys of configuration options passed to init.

Requirements

This package requires an Active LTS Node version (v18+).

Install

Using pnpm:

pnpm add @dot/config

Usage

import { env, init } from '@dot/config';

const defaultConfig = { ... };
const secretConfig = {
  BATCAVE_CODE: `/${env}/batcave/code`
};
const ssmConfig = { ... };
const { get } = init({ defaultConfig, pkg, secretConfig, ssmConfig });

const value = await get('BATCAVE_CODE');

Exports

DotEnv

Type: Enum

An enum representing common Node, deployment, or run environments.

enum DotEnv {
  DEV = 'dev',
  PROD = 'prod',
  STAGE = 'stage',
  TEST = 'test'
}

env

Type: String

Represents the current env value, corresponding to DotEnv.

envPrefix

Type: String

Represents the current env value in a prefix useful for deployment resource identifiers and other identifiers or prefixes. e.g. prod-

init

Type: Function
Returns: { get, put }

Initializes a configuration getter and putter.

Options

defaultConfig

Type: Object

An object whereby keys identify configuration values.

secretConfig

Type: Object

An object whereby keys match AWS SecretsManager names.

ssmConfig

Type: Object

An object whereby keys match AWS SSM Parameter Store paths.

get

Type: Function
Parameters: (key: String)
Returns: Promise<String | Number>

Get a value for the specified key. The key may represent a key present on:

  • process.env
  • The default configuration object
  • The secrets configuration object
  • The SSM configuration object

If the key does not exist, or the value returned from any of the possible sources is undefined, a RangeError is thrown.

const name = await get('BATMAN');

put

Type: Function
Parameters: (key: String, value: any)
Returns: Promise<AWS Response>

Saves a value to the specified key, which corresponds to an AWS SSM Parameter Path. This function is limited to AWS SSM Parameter Store.

await put('DB_NAME', 'batman');

Meta

CONTRIBUTING

LICENSE (Mozilla Public License)