summaryrefslogtreecommitdiffstats
path: root/modules.d/01systemd-integritysetup/module-setup.sh
diff options
context:
space:
mode:
Diffstat (limited to '')
-rwxr-xr-xmodules.d/01systemd-integritysetup/module-setup.sh59
1 files changed, 59 insertions, 0 deletions
diff --git a/modules.d/01systemd-integritysetup/module-setup.sh b/modules.d/01systemd-integritysetup/module-setup.sh
new file mode 100755
index 0000000..3d17640
--- /dev/null
+++ b/modules.d/01systemd-integritysetup/module-setup.sh
@@ -0,0 +1,59 @@
+#!/bin/bash
+# This file is part of dracut.
+# SPDX-License-Identifier: GPL-2.0-or-later
+
+# Prerequisite check(s) for module.
+check() {
+
+ # If the binary(s) requirements are not fulfilled the module can't be installed.
+ require_binaries \
+ "$systemdutildir"/systemd-integritysetup \
+ "$systemdutildir"/system-generators/systemd-integritysetup-generator \
+ || return 1
+
+ # 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 dm
+ # Return 0 to include the dependent module(s) in the initramfs.
+ return 0
+
+}
+
+installkernel() {
+ instmods dm-integrity
+}
+
+# Install the required file(s) and directories for the module in the initramfs.
+install() {
+
+ inst_multiple -o \
+ "$systemdutildir"/systemd-integritysetup \
+ "$systemdutildir"/system-generators/systemd-integritysetup-generator \
+ "$systemdsystemunitdir"/integritysetup-pre.target \
+ "$systemdsystemunitdir"/integritysetup.target \
+ "$systemdsystemunitdir"/sysinit.target.wants/integritysetup.target
+
+ # Install the hosts local user configurations if enabled.
+ if [[ $hostonly ]]; then
+ inst_multiple -H -o \
+ /etc/integritytab \
+ "$systemdsystemconfdir"/integritysetup.target \
+ "$systemdsystemconfdir/integritysetup.target.wants/*.target" \
+ "$systemdsystemconfdir"/integritysetup-pre.target \
+ "$systemdsystemconfdir/integritysetup-pre.target.wants/*.target" \
+ "$systemdsystemconfdir"/sysinit.target.wants/integritysetup.target \
+ "$systemdsystemconfdir/sysinit.target.wants/integritysetup.target.wants/*.target"
+ fi
+
+ # Install required libraries.
+ _arch=${DRACUT_ARCH:-$(uname -m)}
+ inst_libdir_file {"tls/$_arch/",tls/,"$_arch/",}"libcryptsetup.so.*"
+
+}