Skip to content
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

Epic: caBLE authenticator support #259

Open
3 of 9 tasks
micolous opened this issue Jan 14, 2023 · 5 comments
Open
3 of 9 tasks

Epic: caBLE authenticator support #259

micolous opened this issue Jan 14, 2023 · 5 comments
Labels
cable Issues relating to caBLE (Cloud-assisted Bluetooth Low Energy authenticators) enhancement New feature or request

Comments

@micolous
Copy link
Collaborator

micolous commented Jan 14, 2023

This is to track work and ideas relating to supporting caBLE authenticators (aka: authenticator on your mobile device), and acting as a caBLE authenticator.

At present (2023-08-10), our implementation of the caBLE authenticator and initiator is fairly complete; the only gaps are DPK and pairing (both are Android-only). It's otherwise completely usable as an initiator with Android and iOS devices acting as authenticators.

Merged

In review

In progress

Future work ideas

Not a commitment to deliver it, and not in any particular order:

  • Port to some embedded system
  • Tunnel server frontend

Authenticator features

Initiator features

  • Hybrid Transport (caBLE): State-assisted Transactions #446 (pairing / Linking / "Remember Device" (Android + Chrome)). The current implementation just ignores it, because Chrome on Android will always send it.
  • DevicePubKey extension (Android + Chrome). You can have the authenticator device attest its identity and give out a SafetyNet attestation.

Discarded work ideas

@Firstyear
Copy link
Member

I'm not sure DPK is worth supporting at this point as previously discussed.

@micolous micolous added the cable Issues relating to caBLE (Cloud-assisted Bluetooth Low Energy authenticators) label Feb 3, 2023
@micolous micolous mentioned this issue Mar 20, 2023
2 tasks
@micolous
Copy link
Collaborator Author

FIDO Alliance recently published a review draft of the CTAP 2.2 specification, which includes a caBLE specification. Some observations:

  • The protocol for an authenticator establishing a connection to a tunnel server is considered "a private detail of the authenticator's implementation".

    As a result, I've dropped supporting Apple's tunnel server as an authenticator from the list, because webauthn-authenticator-rs (and our cable-tunnel-server) implements Chromium's protocol, and I presume Apple will do something different here.

  • Chromium differs from the spec in many ways, which would make it incompatible. I'm otherwise pretty confident that webauthn-authenticator-rs implements the protocol correctly-enough.

  • The major gap for webauthn-authenticator-rs is implementing pairing (state-assisted transactions); though I think only Android implements it.

    From the looks of it, the dependency on Firebase Cloud Messaging would make it difficult to implement an authenticator using a non-first-party tunnel server, and also makes implementing pairing on our cable-tunnel-server somewhat complicated.

@Firstyear
Copy link
Member

I think for the moment that what we have is a really good demonstration of what's possible, especially for other libraries like the webauthn portal library, but until there is more demand outside of testing and smaller use cases we probably don't want to stress about details like pairing :)

@micolous
Copy link
Collaborator Author

The main issue with pairing is that the library would need a place to store some state (the contact list), and interfaces to manipulate it. This would make things more complicated for an application using webauthn-authenticator-rs.

AFAICT only Android supports pairing, and I'd like to see another implementation before going down that rabbit hole. However, I don't know if Apple will even bother with that, given that the Apple ecosystem solution is that applications use their platform WebAuthn APIs to access the iCloud Keychain.

@AlfioEmanueleFresta
Copy link

AlfioEmanueleFresta commented Aug 4, 2024

I'd like to try and pick up the work on State-assisted Transactions (STs). I believe hybrid transport is crucial to unlock Passkey adoption across platforms, and STs are highly desirable for our use case.

As @micolous pointed out, this requires storing authenticator information. I propose applications wanting to use state-assisted transactions should provide storage, by means of optionally providing an implementation of a storage-provider interface. For example, it would be the responsibility of the Linux FIDO2 portal to store known devices, and the security properties of this storage may be adapted depending on the use case - eg. using the TPM to bind the state to a specific device.

Created #446.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
cable Issues relating to caBLE (Cloud-assisted Bluetooth Low Energy authenticators) enhancement New feature or request
Projects
None yet
Development

No branches or pull requests

3 participants