-
Notifications
You must be signed in to change notification settings - Fork 82
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Why not use the PRF extension for WebAuthN signer #246
Comments
Hmm, in my understanding, the snippet you referenced retrieves the public key from the WebAuthN response and imports it into the crypto package. If I remember correctly, the import was needed to convert the public key to get the X and Y coordinates for the signer deployment. I think the majority of authenticators do not support exporting private keys (depends on the implementation, of course) |
Oh. I see, you're right. So, to sign you simply use the following lines: safe-modules/examples/safe-4337-passkeys/src/logic/userOp.ts Lines 317 to 335 in abfafdc
where essentially the message to sign is |
The standard says that the challenge is an arbitrary bytes array: https://w3c.github.io/webauthn/#dom-publickeycredentialrequestoptions-challenge What ends up signed is a 32-byte transaction hash, which is not a large chunk of data. I think they accept arbitrary length data because what ends up being signed is a hash of (authenticator data + hash(client data json, which includes the challenge)). You can see the "Signing procedure" details in the spec here: https://w3c.github.io/webauthn/#signing-procedure |
Thanks for sharing these insights. The link to the specification was pretty useful to understand the details. |
Thank you for sharing the PRF extension! @nlordell had an idea to use the generated key as a private key on a native |
Yeah, that's pretty much what we are testing right now. Tbh it turns out that most of the devices that do not support prf support largeBlob (the Apple ones). Still, extensions require newest versions of the OS (September 2023+ mostly), and I'm not sure I'd recommend that strategy compared to the one you adopted, because in this case we couldn't find a way to avoid exposing the private key (to the running code). |
For reference I documented it here: #249 |
I guess this depends on your threat model right? If you are concerned with leaking secrets from memory, then all signing needs to happen on a trusted authenticator, and the PRF method isn't well suited. That's a pretty hardcore threat model though 😅. |
But this is what's happening in your current implementation, isn't it?
That's probably true, yet a compelling reason to say that a WebAuthN-based wallet is even more secure than traditional wallets... |
Correct. But if we would use PRF then this wouldn't be the case right? Since the client (i.e. browser JS runtime) have access to raw key material.
To me, this makes them equivalent to hardware wallets. The big advantage of Passkey over existing hardware wallets is that devices you already own (your smartphone or Yubikey) become Ethereum-enabled signers. So "hardware wallet availability". |
Exactly, so to sum up, also for future readers of this thread:
It is worth mentioning that also the largeBlob extension (for devices that do not support the PRF extension) can be equivalent, as it allows to store a secret on the secure device, therefore the Ethereum private key can be stored directly and used on-demand |
We are working on a passkey implementation of signers, so we familiarize a lot with the new example that combines it with EIP-4337 (we were working at this part right now).
However, we are curious about a choice:
safe-modules/examples/safe-4337-passkeys/src/logic/passkeys.ts
Lines 55 to 65 in abfafdc
In this lines you export the private key, potentially making it vulnerable to in-memory attacks.
Why not using instead the prf extension of WebAuthN (currently supported only on Chrome), to avoid exposing the key altogether?
The text was updated successfully, but these errors were encountered: