Node Vault
node-vault is a Javascript HTTP client for HashiCorp's Vault API
that allows you to have typesafe access to the API using TypeScript
and Zod.
👀 Features
- Simple API
- Typesafe and Validated Requests from Zod
- Extendable using Custom Commands
📦 Installation
npm install @litehex/node-vault
📖 Usage
Init and unseal vault
import { Client } from '@litehex/node-vault';
const vc = new Client({
apiVersion: 'v1',
endpoint: 'http://127.0.0.1:8200',
token: 'hv.xxxxxxxxxxxxxxxxxxxxx'
});
const init = await vc.init({ secret_shares: 1, secret_threshold: 1 });
console.log(init);
const { keys, root_token } = init;
vc.token = root_token;
const unsealed = await vc.unseal({ key: keys[0] });
console.log(unsealed);
Create Key/Value V2 engine
const mounted = await vc.mount({
mountPath: 'my-secret',
type: 'kv-v2'
});
console.log(mounted);
const info = await vc.engineInfo({ mountPath: 'my-secret' });
console.log(info);
Write, read and delete secrets
const mountPath = 'my-secret';
const path = 'hello';
const write = await vc.kv2.write({
mountPath,
path,
data: { foo: 'bar' }
});
console.log(write);
const read = await vc.kv2.read({ mountPath, path });
console.log(read);
const deleted = await vc.kv2.deleteLatest({ mountPath, path });
console.log(deleted);
📚 Documentation
For complete usages, please dive into the Wiki.
For all configuration options, please see the API docs.
🤝 Contributing
You can contribute to this project by opening an issue or a pull request
on GitHub. Feel free to contribute, we care about your ideas and
suggestions.
Relevant
License
MIT © Shahrad Elahi