browser-crypto

Node.js crypto module subset for browser

Usage no npm install needed!

<script type="module">
  import browserCrypto from 'https://cdn.skypack.dev/browser-crypto';
</script>

README

Node.js 'crypto' module subset for browser

Package contents:

  • Buffer
  • getCiphers()
  • createECDH()
  • createCipher() (deprecated, use createCipheriv() instead)
  • createCipheriv()
  • createDecipher() (deprecated, use createDecipheriv() instead)
  • createDecipheriv()
  • pbkdf2
  • pbkdf2Sync

Usage example:

import { Buffer, createECDH, createCipheriv, createDecipheriv } from 'browser-crypto';

const ecdh1 = createECDH('secp256k1');
const ecdh2 = createECDH('secp256k1');

const publicKey1 = ecdh1.generateKeys();
const publicKey2 = ecdh2.generateKeys();

const secret1 = ecdh1.computeSecret(publicKey2);
const secret2 = ecdh2.computeSecret(publicKey1);

const iv = Buffer.alloc(16);
const data = Buffer.from('abcdef');

const cipher = createCipheriv('aes256', secret1, iv);
const encrypted = Buffer.concat([cipher.update(data), cipher.final()]);

const decipher = createDecipheriv('aes256', secret2, iv);
const decrypted = Buffer.concat([decipher.update(encrypted), decipher.final()]);
console.log(decrypted.toString());

const derivedKey = pbkdf2('password', 'salt', 1, 32, 'sha512', (error, derivedKey) => {
  if (error) throw error;
  console.log(derivedKey);
});

const derivedKey = pbkdf2Sync('password', 'salt', 1, 32, 'sha512');
console.log(derivedKey);