Some progress with FIDO2 Authenticator

Last (and previous) weekends I've spent on the real implementation of FIDO2 WebAuthN protocol. In reality, the problem is more deep and difficult than I was thinking before, so I have re-implemented the GATT server on Android to have higher-level language and libraries and better debugging capabilities.

At the moment I have fully working «Make Credential» workflow with proper certificate generation and response signing. Here's short video with demonstration of the process

While implementing I've found one inconsistency in the documentation. When you're sending back response with new credential the specification defines indexes of authData and fmt as 0x01 and 0x02 respectively, while Chrome requires these parameters swapped — 0x01 should be fmt and 0x02 should be authData.

As well I think the user's interface is quite misleading if you work with BLE protocol. Chrome asks the user which authenticator should be used while the actual communication with the device is already going in the background. User has no clue they should open up the device and perform next authentication steps with it.

So, the project is slowly moving forward.