Zbigniew Jędrzejewski-Szmek ca73a2
From caf058da753c7aae6fbf03feb68e689a8d8265c6 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek ca73a2
From: Dave Reisner <dreisner@archlinux.org>
Zbigniew Jędrzejewski-Szmek ca73a2
Date: Sat, 8 Feb 2014 12:54:58 -0500
Zbigniew Jędrzejewski-Szmek ca73a2
Subject: [PATCH] cryptsetup-generator: auto add deps for device as password
Zbigniew Jędrzejewski-Szmek ca73a2
Zbigniew Jędrzejewski-Szmek ca73a2
If the password is a device file, we can add Requires/After dependencies
Zbigniew Jędrzejewski-Szmek ca73a2
on the device rather than requiring the user to do so.
Zbigniew Jędrzejewski-Szmek ca73a2
---
Zbigniew Jędrzejewski-Szmek ca73a2
 src/cryptsetup/cryptsetup-generator.c | 20 +++++++++++++++-----
Zbigniew Jędrzejewski-Szmek ca73a2
 1 file changed, 15 insertions(+), 5 deletions(-)
Zbigniew Jędrzejewski-Szmek ca73a2
Zbigniew Jędrzejewski-Szmek ca73a2
diff --git a/src/cryptsetup/cryptsetup-generator.c b/src/cryptsetup/cryptsetup-generator.c
Zbigniew Jędrzejewski-Szmek ca73a2
index e1798a3..00891f1 100644
Zbigniew Jędrzejewski-Szmek ca73a2
--- a/src/cryptsetup/cryptsetup-generator.c
Zbigniew Jędrzejewski-Szmek ca73a2
+++ b/src/cryptsetup/cryptsetup-generator.c
Zbigniew Jędrzejewski-Szmek ca73a2
@@ -131,11 +131,21 @@ static int create_disk(
Zbigniew Jędrzejewski-Szmek ca73a2
                     streq(password, "/dev/random") ||
Zbigniew Jędrzejewski-Szmek ca73a2
                     streq(password, "/dev/hw_random"))
Zbigniew Jędrzejewski-Szmek ca73a2
                         fputs("After=systemd-random-seed.service\n", f);
Zbigniew Jędrzejewski-Szmek ca73a2
-                else if (!streq(password, "-") &&
Zbigniew Jędrzejewski-Szmek ca73a2
-                         !streq(password, "none"))
Zbigniew Jędrzejewski-Szmek ca73a2
-                        fprintf(f,
Zbigniew Jędrzejewski-Szmek ca73a2
-                                "RequiresMountsFor=%s\n",
Zbigniew Jędrzejewski-Szmek ca73a2
-                                password);
Zbigniew Jędrzejewski-Szmek ca73a2
+
Zbigniew Jędrzejewski-Szmek ca73a2
+                else if (!streq(password, "-") && !streq(password, "none")) {
Zbigniew Jędrzejewski-Szmek ca73a2
+                        _cleanup_free_ char *uu = fstab_node_to_udev_node(password);
Zbigniew Jędrzejewski-Szmek ca73a2
+                        if (uu == NULL)
Zbigniew Jędrzejewski-Szmek ca73a2
+                                return log_oom();
Zbigniew Jędrzejewski-Szmek ca73a2
+
Zbigniew Jędrzejewski-Szmek ca73a2
+                        if (is_device_path(uu)) {
Zbigniew Jędrzejewski-Szmek ca73a2
+                                _cleanup_free_ char *dd = unit_name_from_path(uu, ".device");
Zbigniew Jędrzejewski-Szmek ca73a2
+                                if (dd == NULL)
Zbigniew Jędrzejewski-Szmek ca73a2
+                                        return log_oom();
Zbigniew Jędrzejewski-Szmek ca73a2
+
Zbigniew Jędrzejewski-Szmek ca73a2
+                                fprintf(f, "After=%1$s\nRequires=%1$s\n", dd);
Zbigniew Jędrzejewski-Szmek ca73a2
+                        } else
Zbigniew Jędrzejewski-Szmek ca73a2
+                                fprintf(f, "RequiresMountsFor=%s\n", password);
Zbigniew Jędrzejewski-Szmek ca73a2
+                }
Zbigniew Jędrzejewski-Szmek ca73a2
         }
Zbigniew Jędrzejewski-Szmek ca73a2
 
Zbigniew Jędrzejewski-Szmek ca73a2
         if (is_device_path(u))