aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAntonio Alvarez Feijoo <antonio.feijoo@suse.com>2021-11-24 08:24:07 +0100
committerJóhann B. Guðmundsson <johannbg@gmail.com>2021-11-24 09:54:44 +0000
commit049973b708298ea0ce1ac9c869b404f4c718eff3 (patch)
tree5367e77c815ed637e5746748370245fe6b961fdb
parent5d990a004b5ae6863f2c9a633b184c07dd73563d (diff)
downloaddracut-049973b708298ea0ce1ac9c869b404f4c718eff3.tar.gz
feat(fido2): introducing the fido2 module
This module allows to unlock an encrypted filesystem using a FIDO2 security token.
-rwxr-xr-xmodules.d/91fido2/module-setup.sh28
-rw-r--r--pkgbuild/dracut.spec1
2 files changed, 29 insertions, 0 deletions
diff --git a/modules.d/91fido2/module-setup.sh b/modules.d/91fido2/module-setup.sh
new file mode 100755
index 00000000..9078ee89
--- /dev/null
+++ b/modules.d/91fido2/module-setup.sh
@@ -0,0 +1,28 @@
+#!/bin/bash
+# This file is part of dracut.
+# SPDX-License-Identifier: GPL-2.0-or-later
+
+# Prerequisite check(s) for module.
+check() {
+ # Return 255 to only include the module, if another module requires it.
+ return 255
+}
+
+# Module dependency requirements.
+depends() {
+ # This module has external dependency on other module(s).
+ echo systemd-udevd
+ # Return 0 to include the dependent module(s) in the initramfs.
+ return 0
+}
+
+# Install the required file(s) and directories for the module in the initramfs.
+install() {
+ # Install required libraries.
+ _arch=${DRACUT_ARCH:-$(uname -m)}
+ inst_libdir_file \
+ {"tls/$_arch/",tls/,"$_arch/",}"libfido2.so.*" \
+ {"tls/$_arch/",tls/,"$_arch/",}"libcryptsetup.so.*" \
+ {"tls/$_arch/",tls/,"$_arch/",}"libcbor.so.*" \
+ {"tls/$_arch/",tls/,"$_arch/",}"libhidapi-hidraw.so.*"
+}
diff --git a/pkgbuild/dracut.spec b/pkgbuild/dracut.spec
index 04c61f90..df031913 100644
--- a/pkgbuild/dracut.spec
+++ b/pkgbuild/dracut.spec
@@ -372,6 +372,7 @@ echo 'dracut_rescue_image="yes"' > $RPM_BUILD_ROOT%{dracutlibdir}/dracut.conf.d/
%{dracutlibdir}/modules.d/90qemu
%{dracutlibdir}/modules.d/91crypt-gpg
%{dracutlibdir}/modules.d/91crypt-loop
+%{dracutlibdir}/modules.d/91fido2
%{dracutlibdir}/modules.d/91tpm2-tss
%{dracutlibdir}/modules.d/95debug
%{dracutlibdir}/modules.d/95fstab-sys