Skip to content

Mb/2807 webauthn support for accounts#2846

Open
mohnishbaker wants to merge 2 commits intoHeyPuter:mainfrom
mohnishbaker:mb/2807-webauthn-support-for-accounts
Open

Mb/2807 webauthn support for accounts#2846
mohnishbaker wants to merge 2 commits intoHeyPuter:mainfrom
mohnishbaker:mb/2807-webauthn-support-for-accounts

Conversation

@mohnishbaker
Copy link
Copy Markdown

Add WebAuthn/Passkey authentication support

This PR adds passkey (WebAuthn) support as a second authentication factor and login method for Puter accounts.

What's changed:

Backend: New WebAuthnService handles credential registration and verification using @simplewebauthn/server. A new /api/v3/auth/webauthn router exposes endpoints for registration and authentication challenges/responses. A SQLite migration (0047) stores passkey credentials per user.

Frontend: New UIWindowWebAuthnSetup guides users through registering a passkey using @simplewebauthn/browser. The Security settings tab (UITabSecurity) now lists registered passkeys and allows removing them. The login window (UIWindowLogin) supports signing in with a passkey instead of a password.

How to test:

Log in to Puter and open Settings → Security
Click "Add Passkey" and complete the browser prompt
Log out and log back in using the "Sign in with Passkey" option

@CLAassistant
Copy link
Copy Markdown

CLA assistant check
Thank you for your submission! We really appreciate it. Like many open source projects, we ask that you sign our Contributor License Agreement before we can accept your contribution.


Mohnish Baker seems not to be a GitHub user. You need a GitHub account to be able to sign the CLA. If you have already a GitHub account, please add the email address used for this commit to your account.
You have signed the CLA already but the status is still pending? Let us recheck it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants