A repository with full stack WebAuthn API examples.
-
Authenticate with passkeys - Passkeys with SimpleWebAuthn & Firebase
- Creating (user registration), retrieving (user login), linking multiple, and removing passkeys.
- Passkeys autofill.
- Formatting and parsing of WebAuthn API request / responses done via SimpleWebAuthn library.
- Built with Firebase Auth and Firestore SDKs.
- 👉 Check out the demo
-
Upgrade to passkeys – From email/password to passkeys with SimpleWebAuthn & Firebase
- A user registers with traditional email/password and verifies their email afterwards.
- Then the user can link passkey/s and therefore upgrades to MFA.
- The user can downgrade to single-factor authentication by removing all their passkeys.
- Built with SimpleWebAuthn, Firebase Auth and Firestore SDKs.
- 👉 Check out the demo
Let me share with you a developer guide to passkeys in my Welcome to the world of passkeys blog post (česky Vítejte ve světě passkeys).
- The whole project is managed using tuborepo.
- All examples are in NextJS (React) framework.
- API calls are handled with React Tanstack query on client.
- API endpoints are built via NextJS API routes.
- Forms are built with react-hook-form and validated with zod schemas.
- Material UI with styled components as UI SDK.
-
Initialize package manager: Make sure you're running Node v20. Then initialize a package manager:
corepack enable corepack install
It finds
packageManager
field and installs Yarn 4. -
Install dependencies:
yarn install --immutable
-
Note that common code of each example is placed in
packages/common
(for client and server). -
Then continue with final steps for specific example:
Please, open a Github issue. Thank you. ❤️