Supply your environment with the AWS Systems Manager Parameter Store
yarn add @n1ru4l/ssm-parameter-env
npm install @n1ru4l/ssm-parameter-env
"use strict";
const AWS = require("aws-sdk");
const ssm = new AWS.SSM();
const createGetEnvironment = require("@n1ru4l/ssm-parameter-env");
const expect = require("expect");
// You would probably use process.env
const env = {
MY_SCURR: "ssm:/Scurr/Burr/Eagle",
MY_BAZZ: "Passthrough value"
};
// Create outside of handler to use in-memory caching (default is 5 minutes)
const getEnvironment = createGetEnvironment({
env,
ssm,
expires: 5 * 60 * 1000
});
module.exports.handler = (event, context, callback) => {
getEnvironment().then(env => {
expect(env).toEqual({
MY_SCURR: "TOP SECRET VALUE",
MY_BAZZ: "Passthrough value"
}); // true
const response = {
statusCode: 200,
body: JSON.stringify({
message: env.MY_SCURR
})
};
callback(null, response);
});
};
More documentation will follow soon. For more detail you can take a look at the tests 😇.
This plugin should work out of the box with serverless-offline.
You should not uny any environment variables prefixed with ssm:
in your local development environment to prevent any request to AWS.
This document should cover all info about permissions.
You will have to give permissions to your target for the following actions: ssm:GetParameters
and kms:Decrypt
.
I recommend to group your ssm parameters with a prefix (e.g. my-project-production/database-password
). By doing so you can restrict the ssm:GetParameters
to a subset of ssm parameters that start with the shared prefix (e.g. my-project-production/*
).
I use serverless and I don't care, I am testing and I just wanne copy paste stuff
If you do not care about fine graned access control just use these iamRoleStatements (serverless):
iamStatements:
- Effect: Allow
Action:
- ssm:GetParameters
Resource: *
- Effect: Allow
Action:
- kms:Decrypt
Resource: *
- Make it compatible to serverless framework (offline mode)
- Test in Real World Application
- Publish to npm
- Implement caching