In this project, we add support for post-quantum algorithms on FIDO2. We implemented Dilithium3 for Signing in WebAuthn and Kyber768 for KEM in CTAP2. The current implementation only supports discoverable (resident) credentials.
FIDO2 involves three main entities:
- authenticator,
- browser and
- server.
We needed to change all these three entities. In our prototype, we use Nitrokey 3 firmware for authenticator
, Firefox browser and java-webauthn-server
from Yubico.
Clone this repository and its submodules.
git clone git@github.com:sandbox-quantum/pqc-fido2-impl.git --recurse-submodules
Note: You have to build liboqs
first.
Go to liboqs-java/
, and follow the Building the OQS dependency instructions.
Next, follow the Building the Java OQS wrapper instructions:
mvn package -P macosx -Dliboqs.include.dir="/usr/local/include" -Dliboqs.lib.dir="/usr/local/lib"
Go to java-webauthn-server/
, run:
./gradlew run
Follow the instructions here (make sure you have Mercurial
installed first) to embed the modified PQC authenticator into Firefox.
The LPC55 Quickstart Guide explains how to compile and flash the firmware on a LPC55 Nitrokey 3 Hacker device or on a LPCXpresso55S69 development board.
Once the device is reset and provisioned following the LPC55 Quickstart Guide, the firmware can be flashed using the following command line:
make -C utils/lpc55-builder flash FEATURES=develop
Hardware setup:
-
LPCXpresso55S69 development board and 2 USB cables.
-
Connect 2 USB cables to two ports: P9 High-Speed ("High Spd" label) and P6 Debug Probe ("Debug Link" label).
-
Install the SEGGER J-Link software bundle
-
Open the SEGGER J-Link Configuration program and make sure the J-Link protocol is being used
The board should appear in the list of devices connected via USB. We will be using the J-Link communication protocol. Therefore, in case the board appears as using the CMSIS-DAP protocol (the default in a new board), we will need to install the J-Link firmware by following these steps. After restart, the board should show up in the configuration tool as a J-Link device.
Go to the nitrokey-3-firmware/
directory and from 2 terminals:
- Terminal 1:
make -C utils/lpc55-builder/ jlink
- Terminal 2:
make -C utils/lpc55-builder/ run FEATURES=develop-no-press
To verify that the board is working as a hardware authenticator, we use the fido2-token
tool from libfido2
:
❯ fido2-token -L
ioreg://4295801683: vendor=0x20a0, product=0x42b2 (Nitrokey Nitrokey 3)
- Visit https://localhost:8443 in the Firefox browser and click on the "Create account with passkey" button. This will initiate the registration process using a resident key.
Select "Proceed" and, if prompted for it, click the USER button on the board / tap the Nitrokey 3 Hacker board.
Output of the successful registration.
In our experiment, Dilithium3 ID is -20
, you can see it in our patched COSEY module
The string DIL3
, Dil
or Dilithium
should appear in the server logs.
- For authentication click "Authenticate with passkey" or "Authenticate with username" to authenticate with the corresponding resident key.
Select "Proceed" and click the USER button on the board / tap the Nitrokey 3 Hacker board.
Output of the successful authentication. Again, the string DIL3
, Dil
or Dilithium
should appear in the server logs.
- MACOS: In case of errors related to
liboqs
in the server, make sureOpenJDK@17
is used (or any other version supportingaarc64
) and add a symlink forliboqs.5.dylib
:
ln -s /usr/local/lib/liboqs.5.dylib /opt/homebrew/Cellar/openjdk@17/17.0.9/libexec/openjdk.jdk/Contents/Home/lib/server/liboqs.5.dylib
Project | Branch | Required by |
---|---|---|
java-webauthn-server | add_Kyber768_Dilithium3_and_liboqs |
|
liboqs-java | update_config_and_fix_error |
java-webauthn-server |
authenticator-rs | add_Kyber_and_Dilithium |
Firefox |
nitrokey-3-firmware | nitrokey-pqc-fido2 |
Nitrokey 3 / LPCXpresso |
trussed | nitrokey-pqc-fido2 |
nitrokey-3-firmware |
fido-authenticator | nitrokey-pqc-fido2 |
nitrokey-3-firmware |
ctap-types | nitrokey-pqc-fido2 |
nitrokey-3-firmware |
cosey | pqc_kyber768_dilithium3 |
fido-authenticator |
usbd-ctaphid | nitrokey-pqc-fido2 |
nitrokey-3-firmware |
PQC FIDO2
project is licensed under both the Apache License, Version 2.0 and MIT License.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.