octosecret-crypto

0.3.0 • Public • Published

octosecret-crypto

CircleCI Known Vulnerabilities NSP Status

Encrypt and decrypt data using RSA keys

What

Nodejs library that wraps openSSL to provide encryption and decryption of files and buffers. This was originally created to provide the crypto layer of octosecret, a CLI that allows easy data encryption and decryption between github users.

Features

  • Encrypt and decrypt files
  • Encrypt and decrypt streams (eg: text, buffer..)
  • Encryption support multiple keys

Install

npm install octosecret-crypto --save

API

File operations:

  • file.encrypt(origin, destination, keys)
  • file.decrypt(origin, destination, [key])

Stream operations:

  • stream.encrypt(data, keys)
  • stream.decrypt(data, [key])

Utils:

  • util.randomSymmetricKey(bytes)
  • util.createEncryptionKey(keys)
  • util.rsa2pkcs8(origin, destination)
  • util.rsaEncrypt(data, pkcs8_file)
  • util.rsaDecrypt(data, privateKey)
  • util.base64Encode(data)
  • util.base64Decode(data)
  • util.fileEncrypt(origin, destination, key)
  • util.fileDecrypt(origin, destination, key)
  • util.bufferEncrypt(buffer, key)
  • util.bufferDecrypt(buffer, key)

Examples

Encrypt and decrypt files

const octosecret = require('octosecret-crypto')
 
// Encrypt "octocat.gif" to "octocat.gif.octosecret" using "public.key"
await octosecret.file.encrypt(`octocat.gif`, `octocat.gif.octosecret`, ['public.key'])
 
// Decrypt "octocat.gif.octosecret" to "octocat.gif" using "id_rsa" key
await octosecret.file.decrypt(`octocat.gif.octosecret`, `octocat.gif`, `~/.ssh/id_rsa`)

Encrypt and decrypt streams

const octosecret = require('octosecret-crypto')
 
// Example data
const dataToEncrypt = "Super secret message"
 
// Encrypt
const encrypted = await octosecret.stream.encrypt(dataToEncrypt, ['public.key'])
 
// Decrypt
const decrypted = await octosecret.stream.decrypt(encrypted, `~/.ssh/id_rsa`)
 
// Convert Buffer to String
const decryptedText = decrypted.toString()
// "Super secret message"

Check __test__ and src/example.js for more examples

License

MIT © Hugo Rodrigues

Readme

Keywords

none

Package Sidebar

Install

npm i octosecret-crypto

Weekly Downloads

0

Version

0.3.0

License

MIT

Unpacked Size

432 kB

Total Files

21

Last publish

Collaborators

  • hugorodrigues