aws-env-variables is a small utility package that gets environment variables from either AWS Secret Manager or AWS Parameter Store
This package will retrieve secrets from AWS and save them in a .env
file
npm i aws-env-variables
This utility package authenticates with AWS through environment variables.
Ensure you have these set, see example below:
$ export AWS_ACCESS_KEY_ID=AKIAIOSFODNN7EXAMPLE
$ export AWS_SECRET_ACCESS_KEY=wJalrXUtnFEMI/K7MDENG/bPxRfiCYEXAMPLEKEY
$ export AWS_DEFAULT_REGION=us-west-2
For more help with this, see the AWS User guide
aws-env-variables
Flag Example
To customise the output path of the .env file. Defaults to project directory
--filePath ./src
To customise the filename of the .env file. Defaults to .env
--fileName .env.test
to pass the Secret name of the secret stored in the Secret Manager
--secretsManagerId prod/tamagotchi
to pass the SSM Param Store file of all the secrets you with to request
--paramStoreFileName prod/helloworld
to set process.env.AWS_SDK_LOAD_CONFIG as true
--loadConfig true
// AWS Secrets Manager
aws-env-variables --secretsManagerId=prod/helloworld
// SSM Param Store
aws-env-variables --paramStoreFileName=./ssmVars.json
// Custom file path and file names
aws-env-variables --secretsManagerId=prod/tamagotchi --filePath=./secrets/ --fileName=.env.local
This should be a json file that has the key as the environment variable key, and the value as the parameter to get from the SSM Parameter Store
Example below:
// ssmVars.json
{
"TEST_ID": "leon-testing-param-store",
"EXAMPLE": "another-aws-secret-name"
}
// produces:
// .env
TEST_ID=supersecretresultfromaws
EXAMPLE=topsecretdata
Using pre-deployment scripts:
// package.json
...
"scripts": {
aws-env-variables --paramStoreFileName=./ssmVars.json
}
Using scripts and environment variables Extension of usage using the config package: