🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket
Book a DemoInstallSign in
Socket

fastify-secrets-aws

Package Overview
Dependencies
Maintainers
0
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

fastify-secrets-aws

Fastify secrets plugin for AWS Secrets Manager

4.0.0
latest
Source
npm
Version published
Weekly downloads
644
-32.42%
Maintainers
0
Weekly downloads
 
Created
Source

Fastify Secrets AWS

ci

Fastify secrets plugin for AWS Secrets Manager.

Installation

npm install --save fastify-secrets-aws

Usage

Get permissions to access AWS Secrets Manager

In order to be able to read from AWS Secrets Manager you will need some permissions.

You will also probably manage permissions in different ways in local dev and production environment.

Local dev environment

In general you may want to use a different secrets manager on your local machine (i.e. fastify-secrets-env to read secrets from env variables).

If you want to run fastify-secrets-aws in the local environment you will need to follow these steps:

  • Create a AWS user with programmatic access via IAM
  • Grant the new user the policy SecretsManagerReadWrite
  • Store the access key id, secret access key and region in your local AWS configuration
  • Ensure that the configuration is loaded by the SDK, which may require setting the AWS_SDK_LOAD_CONFIG environment variable to a truthy value or populate the configuration via environment variables altogether
  • You're ready to run your app

Production environment

If you already have a AWS user you will need to give it access to Secrets Manager by adding the policy SecretsManagerReadWrite.

Otherwise you will need to create a new user with access to Secrets Manager by adding it the same policy SecretsManagerReadWrite.

Add plugin to your fastify instance

const FastifySecrets = require('fastify-secrets-aws')

fastify.register(FastifySecrets, {
  secrets: {
    dbPassword: 'secret-name'
  }
})

secret-name is the name of the secret as created in AWS Secrets Manager.

Access you secrets

await fastify.ready()

console.log(fastify.secrets.dbPassword) // content of 'secret-name'

Plugin options

The plugin only expect the secrets object in the options.

It is a map of keys and resource ids for the secrets. fastify-secrets-aws will decorate the fastify server with a secrets object where keys will be the same keys of the options and the value will be the content of the secret as fetched from AWS Secrets Manager

Contributing

See CONTRIBUTING.md

License

Copyright NearForm Ltd 2020. Licensed under the Apache-2.0 license.

Keywords

fastify

FAQs

Package last updated on 10 Dec 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts