@dmno/bitwarden-plugin

0.0.1 • Public • Published

Check out the docs for more information on how to use DMNO with Bitwarden Secrets Manager.

*** THIS IS PREVIEW SOFTWARE AND SUBJECT TO RAPID CHANGE ***

If you have any questions, please reach out to us on Discord.


@dmno/bitwarden-plugin npm

Securely use your secrets and data from Bitwarden Secrets Manager within DMNO Config Engine.

Plugin

Initialization

You must initialize an instance of the plugin, giving it a unique ID and wiring up the access token to its location within your config schema.

Then you can use the plugin instance which now has authentication, to fetch individual items by their UUID.

For example:

import { DmnoBaseTypes, defineDmnoService, configPath, NodeEnvType, switchBy, configPath } from 'dmno';
import { BitwardenSecretsManagerDmnoPlugin, BitwardenSecretsManagerTypes } from '@dmno/bitwarden-plugin';

const bwsPlugin = new BitwardenSecretsManagerDmnoPlugin('bitwarden', {
  accessToken: configPath('..', 'BWS_TOKEN'),
});

export default defineDmnoService({
  schema: {
    BWS_TOKEN: {
      extends: BitwardenSecretsManagerTypes.machineAccountAccessToken,
    },
    ITEM_FROM_BITWARDEN: {
      value: bwsPlugin.secretById('df2246f1-7889-4d1b-a18e-b219001ee3b3')
    }
    //...

Since the access token is sensitive, you'll need to populate the value of BWS_TOKEN using an override. For local development, you can store the machine access token in your .dmno/.env.local file, and in deployed environments you can set it as an environment variable.

Value Resolvers

Fetch item by UUID

bwsPlugin.secretById(uuid)

Data Types

  • BitwardenSecretsManagerTypes.machineAccountAccessToken
  • BitwardenSecretsManagerTypes.secretId
  • BitwardenSecretsManagerTypes.projectId

Package Sidebar

Install

npm i @dmno/bitwarden-plugin

Weekly Downloads

5

Version

0.0.1

License

MIT

Unpacked Size

22.6 kB

Total Files

6

Last publish

Collaborators

  • philmillman
  • theo