@firebase-web-authn/functions
A Firebase extension for authentication with WebAuthn passkeys.
This package contains a Firebase Function that registers and authenticates WebAuthn passkeys, manages public key credentials in Firestore, and cleans up data if the user cancels the process or unlinks a passkey.

Custom deployment
If you would rather deploy FirebaseWebAuthn from your existing Firebase Functions package,
- Run:
% npm install @firebase-web-authn/functions --save-dev
- Export the API from your Firebase Functions package's
main
file by calling getFirebaseWebAuthnApi
with a config object.
import { initializeApp } from "firebase-admin/app";
import { HttpsFunction } from "firebase-functions";
import { getFirebaseWebAuthnApi } from "@firebase-web-authn/functions";
getApps().length === 0 && initializeApp();
export const firebaseWebAuthnAPI: HttpsFunction = getFirebaseWebAuthnApi({...});
interface FirebaseWebAuthnConfig {
authenticatorAttachment: AuthenticatorAttachment,
relyingPartyName: string,
userVerificationRequirement?: UserVerificationRequirement,
}
- Deploy your Firebase Functions:
% firebase deploy --only functions
Google Cloud setup
- Set up these services in your Firebase project:
- Firebase Authentication and the Anonymous provider.
- Cloud Firestore
- Cloud Functions
- Grant the
Cloud Datastore User
and Service Account Token Creator
roles to the App Engine default service account
principal in Service accounts under App Engine default service account
> Permissions. - Grant the
Cloud Functions Invoker
role to the allUsers
principal in Cloud Functions under firebaseWebAuthnAPI
> Permissions.
Additional setup
For the browser to reach FirebaseWebAuthn, modify your firebase.json
to include a rewrite on each app where you'd like to use passkeys.
{
"hosting": [
{
"target": "...",
"rewrites": [
{
"source": "/firebase-web-authn-api",
"function": "firebaseWebAuthnAPI"
}
]
}
]
}