[![Crates.io](https://img.shields.io/crates/v/fido2luks.svg)](https://crates.io/crates/fido2luks) # fido2luks This will allow you to unlock your luks encrypted disk with an fido2 compatible key Note: This has only been tested under Fedora 31, [Ubuntu 20.04](initramfs-tools/), [NixOS](https://nixos.org/nixos/manual/#sec-luks-file-systems-fido2) using a Solo Key, Trezor Model T ### Setup #### Prerequisites ```rust dnf install clang cargo cryptsetup-devel -y ``` #### Device ```rust git clone https://github.com/shimunn/fido2luks.git && cd fido2luks sudo -E cargo install -f --path . --root /usr cp dracut/96luks-2fa/fido2luks.conf /etc/ echo FIDO2LUKS_CREDENTIAL_ID=$(fido2luks credential [NAME]) >> /etc/fido2luks.conf set -a . /etc/fido2luks.conf sudo -E fido2luks -i add-key /dev/disk/by-uuid/ sudo -E fido2luks -i open /dev/disk/by-uuid/ luks- ``` #### Dracut ```rust cd dracut sudo make install ``` #### Grub Add `rd.luks.2fa=:` to `GRUB_CMDLINE_LINUX` in /etc/default/grub Note: This is only required for your root disk, systemd will try to unlock all other LUKS partions using the same key if you added it using `fido2luks add-key` ```rust grub2-mkconfig > /boot/grub2/grub.cfg ``` I'd also recommend to copy the executable onto /boot so that it is accessible in case you have to access your disk from a rescue system ```rust mkdir /boot/fido2luks/ cp /usr/bin/fido2luks /boot/fido2luks/ cp /etc/fido2luks.conf /boot/fido2luks/ ``` ### Test Just reboot and see if it works, if that's the case you should remove your old less secure password from your LUKS header: ```rust cryptsetup luksHeaderBackup /dev/disk/by-uuid/ --header-backup-file luks_backup_ fido2luks -i add-key --exclusive /dev/disk/by-uuid/ ``` ### Addtional settings #### Password less Remove your previous secret as described in the next section, in case you've already added one. Open `/etc/fido2luks.conf` and replace `FIDO2LUKS_SALT=Ask` with `FIDO2LUKS_SALT=string:` but be warned that this password will be included to into your initramfs. Import the new config into env: ```rust set -a . /etc/fido2luks.conf ``` Then add the new secret to each device and update dracut afterwards `dracut -f` ### Removal Remove `rd.luks.2fa` from `GRUB_CMDLINE_LINUX` in /etc/default/grub ```rust set -a . fido2luks.conf sudo -E fido2luks -i replace-key /dev/disk/by-uuid/ sudo rm -rf /usr/lib/dracut/modules.d/96luks-2fa /etc/dracut.conf.d/luks-2fa.conf /etc/fido2luks.conf ``` ## License Licensed under the Mozilla Public License 2.0, ([LICENSE-MPL](LICENSE) or https://www.mozilla.org/en-US/MPL/2.0/) ### Contribution Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the MPL 2.0 license, shall be dual licensed as above, without any additional terms or conditions.