]> git.ipfire.org Git - thirdparty/dracut.git/commitdiff
feat(systemd-portabled): introducing the systemd-portabled module
authorAntonio Alvarez Feijoo <antonio.feijoo@suse.com>
Fri, 30 Sep 2022 12:37:36 +0000 (14:37 +0200)
committerLaszlo Gombos <laszlo.gombos@gmail.com>
Sat, 22 Oct 2022 01:51:59 +0000 (21:51 -0400)
Introducing the systemd-portabled module.

It's intended to work only with raw binary disk images contained in regular
files, but not with directory trees.

modules.d/01systemd-portabled/module-setup.sh [new file with mode: 0755]
modules.d/01systemd-tmpfiles/module-setup.sh
pkgbuild/dracut.spec

diff --git a/modules.d/01systemd-portabled/module-setup.sh b/modules.d/01systemd-portabled/module-setup.sh
new file mode 100755 (executable)
index 0000000..ccbc11f
--- /dev/null
@@ -0,0 +1,82 @@
+#!/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 \
+        portablectl \
+        "$systemdutildir"/systemd-portabled \
+        || 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 dbus
+    # Return 0 to include the dependent module(s) in the initramfs.
+    return 0
+
+}
+
+# Install kernel module(s).
+installkernel() {
+    instmods loop squashfs
+}
+
+# Install the required file(s) and directories for the module in the initramfs.
+install() {
+
+    # It's intended to work only with raw binary disk images contained in
+    # regular files, but not with directory trees.
+    local _nonraw
+    _nonraw=$(portablectl --no-pager --no-legend list | grep -v " raw " | cut -d ' ' -f1 | tr '\n' ' ')
+    if [ -n "$_nonraw" ]; then
+        dwarn "systemd-portabled: this module only installs raw disk images in the initramfs; skipping: $_nonraw"
+    fi
+
+    inst_multiple -o \
+        "/var/lib/portables/*.raw" \
+        "/usr/lib/portables/*.raw" \
+        "$tmpfilesdir/portables.conf" \
+        "$dbussystem"/org.freedesktop.portable1.conf \
+        "$dbussystemservices"/org.freedesktop.portable1.service \
+        "$systemdutildir"/systemd-portabled \
+        "$systemdutildir/portable/profile/default/*.conf" \
+        "$systemdutildir/portable/profile/nonetwork/*.conf" \
+        "$systemdutildir/portable/profile/strict/*.conf" \
+        "$systemdutildir/portable/profile/trusted/*.conf" \
+        "$systemdsystemunitdir"/systemd-portabled.service \
+        "$systemdsystemunitdir/systemd-portabled.service.d/*.conf" \
+        "$systemdsystemunitdir"/dbus-org.freedesktop.portable1.service \
+        portablectl
+
+    # The existence of this file is required
+    touch "$initdir"/etc/resolv.conf
+
+    # Enable systemd type unit(s)
+    $SYSTEMCTL -q --root "$initdir" add-wants initrd.target systemd-portabled.service
+    $SYSTEMCTL -q --root "$initdir" enable systemd-portabled.service
+
+    # Install the hosts local user configurations if enabled.
+    if [[ $hostonly ]]; then
+        inst_multiple -H -o \
+            "/etc/portables/*.raw" \
+            "$systemdutilconfdir/system.attached/*" \
+            "$systemdutilconfdir/system.attached/*/*" \
+            "$systemdutilconfdir/portable/profile/default/*.conf" \
+            "$systemdutilconfdir/portable/profile/nonetwork/*.conf" \
+            "$systemdutilconfdir/portable/profile/strict/*.conf" \
+            "$systemdutilconfdir/portable/profile/trusted/*.conf" \
+            "$systemdsystemconfdir"/systemd-portabled.service \
+            "$systemdsystemconfdir/systemd-portabled.service.d/*.conf"
+    fi
+
+}
index 63a64d4e6495b22fd9bb62da7ed904ba24789651..fb90c7db9eeddbec398c8086ed9e83f74e105e61 100755 (executable)
@@ -25,7 +25,6 @@ depends() {
 install() {
 
     # Excluding "$tmpfilesdir/home.conf", sets up /home /srv
-    # Excluding "$tmpfilesdir/portables.conf", belongs in seperated portables module
     # Excluding "$tmpfilesdir/journal-nocow.conf", requires spesific btrfs setup
     # Excluding "$tmpfilesdir/legacy.conf", belongs in seperated legacy module
     # Excluding "$tmpfilesdir/systemd-nologin.conf", belongs in seperated pam module
index abeca27ccaeea691ed84525a371d36f94e17b87f..ae74bf7885229db6ae075589dc63ece41ba3e5cb 100644 (file)
@@ -330,6 +330,7 @@ echo 'dracut_rescue_image="yes"' > $RPM_BUILD_ROOT%{dracutlibdir}/dracut.conf.d/
 %{dracutlibdir}/modules.d/01systemd-journald
 %{dracutlibdir}/modules.d/01systemd-ldconfig
 %{dracutlibdir}/modules.d/01systemd-modules-load
+%{dracutlibdir}/modules.d/01systemd-portabled
 %{dracutlibdir}/modules.d/01systemd-pstore
 %{dracutlibdir}/modules.d/01systemd-repart
 %{dracutlibdir}/modules.d/01systemd-resolved