@atcute/crypto#
cryptographic utilities for AT Protocol.
npm install @atcute/crypto
this package provides key generation, signing, and verification for the two elliptic curve systems used by AT Protocol to certify identity and repository data:
p256: uses WebCrypto APIsecp256k1: usesnode:cryptoon Node.js,@noble/secp256k1elsewhere
usage#
creating keypairs#
import { Secp256k1PrivateKeyExportable, P256PrivateKeyExportable } from '@atcute/crypto';
// secp256k1 keypair
const keypair = await Secp256k1PrivateKeyExportable.createKeypair();
// p256 keypair
const p256Keypair = await P256PrivateKeyExportable.createKeypair();
signing data#
// sign() hashes the data and signs it
const data = new Uint8Array([1, 2, 3, 4, 5, 6, 7, 8]);
const sig = await keypair.sign(data);
exporting public keys#
// export as did:key format
const didKey = await keypair.exportPublicKey('did');
// -> "did:key:zQ3shVRtgqTRHC7Lj4DYScoDgReNpsDp3HBnuKBKt1FSXKQ38"
// export as multibase
const multibase = await keypair.exportPublicKey('multibase');
verifying signatures#
import { verifySigWithDidKey } from '@atcute/crypto';
// verify using did:key (automatically detects curve type)
const ok = await verifySigWithDidKey(didKey, sig, data);