@atcute/crypto
v2.3.0
Published
lightweight atproto cryptographic library
Maintainers
Readme
@atcute/crypto
cryptographic utilities for AT Protocol.
npm install @atcute/cryptothis 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);