Solokey

From NixOS Wiki

This article describes how you can integrate Solokeys with NixOS. For the most part you can follow the guide for Yubikey.

Important, of you want to e.g. upgrade your solokey you also need some additonal udev rules. So the following setup allows you to use your key for sudo as well as you are able to update your solokey

 { config, pkgs, ... }:Italic text
 {
 programs.gnupg.agent = {
     enable = true;
     enableSSHSupport = true;
 };
 security.pam.services = {
     login.u2fAuth = true;
     sudo.u2fAuth = true;
 };
 # https://github.com/solokeys/solo2-cli/blob/main/70-solo2.rules
 services.udev.packages = [
     pkgs.yubikey-personalization
     (pkgs.writeTextFile {
     name = "wally_udev";
     text = 
         # NXP LPC55 ROM bootloader (unmodified)
         SUBSYSTEM=="hidraw", ATTRS{idVendor}=="1fc9", ATTRS{idProduct}=="0021", TAG+="uaccess"
         # NXP LPC55 ROM bootloader (with Solo 2 VID:PID)
         SUBSYSTEM=="hidraw", ATTRS{idVendor}=="1209", ATTRS{idProduct}=="b000", TAG+="uaccess"
         # Solo 2
         SUBSYSTEM=="tty", ATTRS{idVendor}=="1209", ATTRS{idProduct}=="beee", TAG+="uaccess"
         # Solo 2
         SUBSYSTEM=="usb", ATTRS{idVendor}=="1209", ATTRS{idProduct}=="beee", TAG+="uaccess"
     ;
     destination = "/etc/udev/rules.d/70-solo2.rules";
     })
 ];
 }