This skill should be used when the user asks to "derive keys", "use Type42", "use BRC-42", "derive child keys", "use BIP32", "use HD keys", "create mnemonic", "convert mnemonic to key", "derive BAP identity keys", "derive encryption keys", or mentions key derivation, hierarchical deterministic wallets, invoice numbers, or child key generation on BSV.
From bsv-skillsnpx claudepluginhub b-open-io/claude-plugins --plugin bsv-skillsThis skill uses the workspace's default tool permissions.
examples/bip32-wallet.tsexamples/mnemonic-to-type42.tsexamples/type42-derivation.tsreferences/bap-derivation.mdreferences/brc-32-bip32.mdreferences/brc-42-type42.mdGuides Next.js Cache Components and Partial Prerendering (PPR) with cacheComponents enabled. Implements 'use cache', cacheLife(), cacheTag(), revalidateTag(), static/dynamic optimization, and cache debugging.
Migrates code, prompts, and API calls from Claude Sonnet 4.0/4.5 or Opus 4.1 to Opus 4.5, updating model strings on Anthropic, AWS, GCP, Azure platforms.
Generates FastAPI project templates with async routes, dependency injection, Pydantic schemas, repository patterns, middleware, and config for PostgreSQL/MongoDB backends.
Two primary approaches for deriving keys on BSV, plus mnemonic support.
| Method | Package | Use Case |
|---|---|---|
| Type42 (BRC-42) | @bsv/sdk | Modern: privacy-preserving, counterparty derivation |
| BIP32 (BRC-32) | @bsv/sdk | Legacy: HD wallets, sequential paths |
| Mnemonic | @bsv/sdk | Seed phrase to master key conversion |
Modern approach using ECDH shared secrets. Provides enhanced privacy and unlimited key derivation.
import { PrivateKey, PublicKey } from "@bsv/sdk";
const masterKey = PrivateKey.fromWif("L1...");
const counterpartyPubKey = masterKey.toPublicKey(); // or another party's key
// Derive child key using invoice number
const childKey = masterKey.deriveChild(counterpartyPubKey, "invoice-123");
const childAddress = childKey.toPublicKey().toAddress();
For protocol-specific derivations, use the format: {securityLevel}-{protocol}-{keyId}
// BAP identity signing key
const bapKey = masterKey.deriveChild(masterKey.toPublicKey(), "1-sigma-identity");
// Encryption key
const encKey = masterKey.deriveChild(masterKey.toPublicKey(), "2-encryption-default");
Type42 enables deriving shared keys between parties without revealing private keys:
// Alice derives key for Bob
const aliceKey = PrivateKey.fromWif("L1...");
const bobPubKey = PublicKey.fromString("02...");
const sharedKey = aliceKey.deriveChild(bobPubKey, "payment-001");
// Bob derives same address using his private key and Alice's public key
const bobKey = PrivateKey.fromWif("K1...");
const alicePubKey = aliceKey.toPublicKey();
const bobDerived = bobKey.deriveChild(alicePubKey, "payment-001");
// bobDerived.toPublicKey().toAddress() === sharedKey.toPublicKey().toAddress()
Traditional hierarchical deterministic derivation for compatibility.
import { HD } from "@bsv/sdk";
// From extended private key
const hdKey = HD.fromString("xprv9s21ZrQH143K...");
// Derive child at path
const child = hdKey.derive("m/44'/0'/0'/0/0");
const address = child.pubKey.toAddress();
const privateKey = child.privKey;
m = master key') = hardened derivation// Standard wallet paths
const receiving = hdKey.derive("m/44'/236'/0'/0/0"); // BSV receiving
const change = hdKey.derive("m/44'/236'/0'/1/0"); // BSV change
// BAP identity path
const bapRoot = hdKey.derive("m/424150'/0'/0'"); // 424150 = BAP in decimal
import { Mnemonic, HD } from "@bsv/sdk";
const mnemonic = Mnemonic.fromString("word1 word2 word3...");
const seed = mnemonic.toSeed();
const hdKey = HD.fromSeed(seed);
For Type42, convert mnemonic to a single master key (not extended key):
import { Mnemonic, Hash, PrivateKey, Utils } from "@bsv/sdk";
const { toHex } = Utils;
const mnemonic = Mnemonic.fromString("dial tunnel valid cry exhaust...");
const seed = mnemonic.toSeed();
// SHA256 of seed produces 256-bit private key
const keyBytes = Hash.sha256(seed);
const masterKey = PrivateKey.fromString(toHex(keyBytes), "hex");
// Use with Type42 derivation
const childKey = masterKey.deriveChild(masterKey.toPublicKey(), "bap:0");
This approach:
| Scenario | Recommended |
|---|---|
| New wallet/identity system | Type42 |
| Privacy-preserving payments | Type42 |
| Counterparty key agreement | Type42 |
| Legacy wallet compatibility | BIP32 |
| Sequential address generation | BIP32 |
| Migration from existing HD wallet | Both (see migration) |
BAP uses a two-level derivation hierarchy:
// Level 1: Member key from path
const memberKey = masterKey.deriveChild(masterKey.toPublicKey(), "bap:0");
// Level 2: Identity signing key using BAP invoice number
const signingKey = memberKey.deriveChild(memberKey.toPublicKey(), "1-sigma-identity");
const signingAddress = signingKey.toPublicKey().toAddress();
For BIP32 legacy:
const memberHD = hdKey.derive("m/424150'/0'/0'/0/0/0");
// Then apply Type42 for signing key
const signingKey = memberHD.privKey.deriveChild(memberHD.pubKey, "1-sigma-identity");
The bsv-bap library implements Type42 with BRC-43 invoice numbers for BAP identities:
import { BAP } from "bsv-bap";
import { PrivateKey } from "@bsv/sdk";
const bap = new BAP({ rootPk: PrivateKey.fromRandom().toWif() });
const identity = bap.newId("Alice");
// Signing key derived with "1-sigma-identity"
const { address, signature } = identity.signMessage(messageBytes);
// Friend encryption key derived with "2-friend-{sha256(friendBapId)}"
const friendPubKey = identity.getEncryptionPublicKeyWithSeed(friendBapId);
const ciphertext = identity.encryptWithSeed("secret", friendBapId);
A CLI is also available: bun add -g bsv-bap (see create-bap-identity skill).
All BSV key derivation standards are documented at:
https://bsv.brc.dev/key-derivation
Key specifications:
references/brc-42-type42.md - Complete Type42 specification and advanced patternsreferences/brc-32-bip32.md - BIP32 legacy derivation detailsreferences/bap-derivation.md - BAP identity key derivation patterns and migrationexamples/type42-derivation.ts - Type42 counterparty key derivationexamples/bip32-wallet.ts - BIP32 HD wallet with standard pathsexamples/mnemonic-to-type42.ts - Convert mnemonic to Type42 master key