Skip to content

doc: example generating keypairs with WebCrypto & node:crypto #10

Description

@coolaj86
'use strict';

let Fs = require('node:fs/promises');

async function generateKeyPair(algo) {
  let keyPair = await crypto.subtle.generateKey(algo, true, ['sign', 'verify']);

  let name = algo.namedCurve || algo.name;

  let privateKeyAb = await crypto.subtle.exportKey('pkcs8', keyPair.privateKey);
  let privateKeyDER = new Uint8Array(privateKeyAb);
  let privateKeyPath = `./key.${name}.der`.toLowerCase();
  await Fs.writeFile(privateKeyPath, privateKeyDER);

  let publicKeyAb = await crypto.subtle.exportKey('spki', keyPair.publicKey);
  let publicKeyDER = new Uint8Array(publicKeyAb);
  let publicKeyPath = `./pub.${name}.der`.toLowerCase();
  await Fs.writeFile(publicKeyPath, publicKeyDER);

  console.info(`Key pair generated and saved as ${privateKeyPath} and ${publicKeyPath}`);
}

let Crypto = require('node:crypto');

async function generateSecp256k1KeyPair() {
  return new Promise(function (resolve, reject) {
    Crypto.generateKeyPair(
      'ec',
      {
        namedCurve: 'secp256k1',
        publicKeyEncoding: {
          type: 'spki',
          format: 'der',
        },
        privateKeyEncoding: {
          type: 'pkcs8',
          format: 'der',
        },
      },
      async function (err, publicKey, privateKey) {
        if (err) {
          return reject(err);
        }

        await Fs.writeFile('./key.secp256k1.der', privateKey);
        await Fs.writeFile('./pub.secp256k1.der', publicKey);

        console.info(
          'secp256k1 key pair generated and saved as ./key.secp256k1.der and ./pub.secp256k1.der',
        );
      },
    );
  });
}

async function main() {
  await generateKeyPair({ name: 'Ed25519' });
  await generateKeyPair({ name: 'ECDSA', namedCurve: 'P-256' });
  // this should be possible with WebCrypto as well, but I don't know the name to use
  //await generateKeyPair({ name: 'ECDSA', namedCurve: 'secp256k1' });
  // it does work with node:crypto
  await generateSecp256k1KeyPair();
}

main().catch(function (err) {
  console.error(err.stack);
  process.exit(1);
});

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type
    No fields configured for issues without a type.

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions