Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@asymmetrik/yadda-secret
Advanced tools
Secret manager for yadda deployments.
DO NOT USE ON FRONTEND
To use this package your node version must support the Proxy object. This is intended to only run on the server-side of the application.
See if your environment supports Proxies
For best ease of use it is recommended to use Yadda as your deployment tool. Otherwise these variables will need to be defined in the environment in order for this tool to work.
__YADDA__DEPLOYMENT_SECRET_TABLE__
: DynamoDB table which holds the secrets__YADDA__DEPLOYMENT_SECRET_TABLE_REGION__
: DynamoDB table region__YADDA__DEPLOYMENT_SECRET_PREFIX__
: The secret key prefix (AppName/Region/Environment)__YADDA__DEPLOYMENT_SECRET_KMSALIAS__
: The KMS CMK alias to encrypt and decrypt__YADDA__DEPLOYMENT_SECRET_REGION__
: The region the KMS key resides in (optional)__YADDA__DEPLOYMENT_SECRET_CACHE_BUSTER_KEY__
: The key for the cache buster secret (optional)Developers using this tool will not need access to the CMK but the resulting deployed container will need access.
Usage of Yadda-Secrets is simple enough. From within a configuration file you would pull in the KMSVAR and wrap any environment variables to turn them into KMS variables. The variables are case sensitive.
Note: KMS variables are lazy evaluated, if you don't use a secret it is not retrieved.
const { KMSVAR } = require('@asymmetrik/yadda-secret');
module.exports = {
myCoolApp: 'Hail Hydra',
hydraPassphrase: KMSVAR('HYRDA_PASSPHRASE'),
hydraSecret: KMSVAR('HYRDA_SECRET'),
};
However you manage to distribute your configuration is irrelevant but the actual object must be wrapped
with the KMS_Helper
. Due to the nature of secrets you must keep a hold of the resulting object as
every invocation of the Yadda-Secret wrapper will result in a new secret cache nothing is stored in the
yadda-secret module so someone can't attempt to load the module and get access to your secrets in that way.
This does not protect your AWS keys from being picked up during a NPM install.
const KMSWrapper = require('@asymmetrik/yadda-secret');
module.exports = function(env){
const config = readConfigFiles();
return KMSWrapper().KMS_Handler(config);
};
The resolution order of KMSVAR's are implemented as followed:
KMSVAR(secret)
-> process.env[secret]
-> credentialStore.get(secret)
Meaning if the variable exists in the environment (not in the store cache) it will return that value through a promise. If it is not in the environment it will attempt to get the secret through the credential store. It will return the raw payload from the secret store (Credstash)
The business logic code will have to be structured to leverage retrieving the secrets as promises.
function BusinessController(app) {
return {
create(req){
// Pulling a single config variable
return app.config.hydraPassphrase.then((passphrase) => {
... do some logic with it ...
});
}
find(req){
// Pulling multiple config variables
return Promise.all([
app.config.hydraPassphrase,
app.config.hydraSecret,
])
.then(([passphrase, secret]) => {
... do logic with passphrase and secret ...
});
}
}
}
The preferred option is to keep your configs the same and define the test values in the environment, if your testing doesn't easily allow for that configuration you're able to pass a second argument to KMSVAR.
The second argument will transform your secret to resolve the given value and not touch the secrets database.
const { KMSVAR } = require('@asymmetrik/yadda-secret');
module.exports = {
myCoolApp: 'Hail Hydra',
hydraPassphrase: KMSVAR('HYRDA_PASSPHRASE', 'secret_phrase'),
hydraSecret: KMSVAR('HYRDA_SECRET', 'secretive_secret'),
};
FAQs
Client secret library
We found that @asymmetrik/yadda-secret demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
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.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.