docker-secret
Utility for retrieving docker secrets.
Usage
Given that you have created secrets for your docker swarm
printf "myUsername" | docker secret create USERNAME -
printf "mySuperSecret" | docker secret create PASSWORD -
You can retrieve secrets via the following methods:
secrets
Loads secrets defined in the /run/secrets
directory. To load from a different directory, refer to getSecrets(dir)
.
import { secrets } from "docker-secret";
mongoose.connect(
`mongodb://${secrets.USERNAME}:${secrets.PASSWORD}@mongodb/mydb`
);
getSecrets<Secrets>(dir?: string): Secrets
You can read secrets from a directory you define. This is useful for loading secrets from a different directory during development.
import { getSecrets } from "docker-secret";
const secrets = getSecrets(process.env.SECRET_DIR);
secrets.USERNAME;
secrets.PASSWORD;
secrets.RANDOM;
type Credentials = {
USERNAME: string;
PASSWORD: string;
};
const secrets = getSecrets<Credentials>(process.env.SECRET_DIR);
secrets.USERNAME;
secrets.PASSWORD;
secrets.RANDOM;
const secrets = getSecrets<Credentials>();