@oslojs/webauthn documentation
A JavaScript library for working with the Web Authentication API on the server by Oslo.
- Runtime-agnostic
- No third-party dependencies
- Fully typed
import { parseAttestationObject, COSEKeyType, coseAlgorithmES256 } from "@oslojs/webauthn";
const { attestationStatement, authenticatorData } = await parseAttestationObject(encoded);
if (!authenticatorData.userPresent || !authenticatorData.userVerified) {
throw new Error("User must be verified");
}
if (!authenticatorData.verifyRelyingPartyIdHash("example.com")) {
throw new Error("Invalid relying party ID hash");
}
if (authenticatorData.credential === null) {
throw new Error("Expected credential");
}
if (authenticatorData.credential.publicKey.type() !== COSEKeyType.EC2) {
throw new Error("Unsupported algorithm");
}
if (authenticatorData.credential.publicKey.algorithm() !== coseAlgorithmES256) {
throw new Error("Unsupported algorithm");
}
const publicKey = authenticatorData.credential.publicKey.ec2();
This package currently does not support attestation extensions and also does not provide APIs for verifying attestation statements (e.g. FIDO-U2F, TPM).
Installation
npm i @oslojs/webauthn
Prerequisites
This package requires the Web Crypto API. This is available in most modern runtimes, including Node.js 20+, Deno, Bun, and Cloudflare Workers. The big exception is Node.js 16 and 18. Make sure to polyfill it using webcrypto
.
import { webcrypto } from "node:crypto";
globalThis.crypto = webcrypto;
Alternatively, add the --experimental-global-webcrypto
flag when executing files.
node --experimental-global-webcrypto index.js