kms-decrypt
TypeScript icon, indicating that this package has built-in type declarations

1.0.0-beta.6 • Public • Published

KMS Decryption

A simple package that takes a path to a file that's been encrypted with KMS and returns the decrypted contents.

Usage

// Install the package
npm install @pluralsight/kms-decrypt
// Then in a file where you want to use the package
 
import {Decrypt, KmsClientInfo} from 'kms-decrypt'
 
const kmsValues: KmsClientInfo = {
  projectId:`name-of-your-gcp-project`,
  keyRingId:`name-of-your-keyring`,
  cryptoKeyId : `name-of-your-key`,
  location: `location`
}
 
export const yourFunction = async(): Promise<void> =>{
 
const decryption = new Decrypt(kmsValues)
const encryptedFilePath = `/some/path/encryptedFilename.encrypted`
// another example, assuming you have a folder named secrets at the root level
// const encryptedFilePath = path.resolve(__dirname, `./secrets/Filename.encrypted`)
const testToken = await decryption.decryptToString(encryptedFilePath)
}

Decrypt.test has an integration test. You need to encrypt the testSecret.txt file with your credentials and put the testSecret.encrypted file in the src folder. Then create a file named `.clientConfig.ts like this:

import * as I from './Interfaces'
 
export const kmsValues: I.KmsClientInfo = {
  projectId: `your-project-name`,
  keyRingId: `your-ring`,
  cryptoKeyId: `your-key`,
  location: `global`,
}

The location can be specific to what you set when you created your key credentials.

Here's the gcloud SDK command that will encrypt the file once you substitute in your key ring and key.
gcloud kms encrypt --location global --keyring <your-key-ring> --key <your-key> --plaintext-file testSecret.txt --ciphertext-file testSecret.encrypted

Package Sidebar

Install

npm i kms-decrypt

Weekly Downloads

0

Version

1.0.0-beta.6

License

GPL-3.0-or-later

Unpacked Size

4.96 kB

Total Files

8

Last publish

Collaborators

  • rolias