Blame SOURCES/0048-options-allow-a-UUID-as-identifier-for-key.patch

da373f
From 88c4dc1e5b9f9e545c89e8b8ee6878f57df3139c Mon Sep 17 00:00:00 2001
3efd08
From: Pino Toscano <ptoscano@redhat.com>
3efd08
Date: Fri, 29 Nov 2019 12:07:13 +0100
3efd08
Subject: [PATCH] options: allow a UUID as identifier for --key
3efd08
3efd08
This way it is possible to specify the UUID of the LUKS device instead
3efd08
of the libguestfs device name to decrypt a device during the inspection.
3efd08
3efd08
Make the usage of the new luks_uuid API conditional, so other projects
3efd08
using the common submodule do not require a libguestfs version bump.
3efd08
3efd08
(cherry picked from commit bb4a2dc17a78b53437896d4215ae82df8e11b788
3efd08
in libguestfs-common)
3efd08
3efd08
PT: the documentation was amended manually.
3efd08
---
3efd08
 cat/virt-cat.pod               | 4 ++--
3efd08
 cat/virt-log.pod               | 4 ++--
3efd08
 cat/virt-ls.pod                | 4 ++--
3efd08
 cat/virt-tail.pod              | 4 ++--
3efd08
 common/options/decrypt.c       | 8 +++++++-
3efd08
 common/options/keys.c          | 4 ++--
3efd08
 common/options/options.h       | 6 +++---
3efd08
 customize/virt-customize.pod   | 4 ++--
3efd08
 diff/virt-diff.pod             | 4 ++--
3efd08
 edit/virt-edit.pod             | 4 ++--
3efd08
 fish/guestfish.pod             | 4 ++--
3efd08
 fuse/guestmount.pod            | 4 ++--
3efd08
 get-kernel/virt-get-kernel.pod | 4 ++--
3efd08
 inspector/virt-inspector.pod   | 4 ++--
3efd08
 sparsify/virt-sparsify.pod     | 4 ++--
3efd08
 sysprep/virt-sysprep.pod       | 4 ++--
3efd08
 v2v/virt-v2v.pod               | 4 ++--
3efd08
 17 files changed, 40 insertions(+), 34 deletions(-)
3efd08
3efd08
diff --git a/cat/virt-cat.pod b/cat/virt-cat.pod
3efd08
index b0301d636..2cea291ac 100644
3efd08
--- a/cat/virt-cat.pod
3efd08
+++ b/cat/virt-cat.pod
3efd08
@@ -124,8 +124,8 @@ security problem with malicious guests (CVE-2010-3851).
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/cat/virt-log.pod b/cat/virt-log.pod
3efd08
index 0d447b3b5..888108d5f 100644
3efd08
--- a/cat/virt-log.pod
3efd08
+++ b/cat/virt-log.pod
3efd08
@@ -108,8 +108,8 @@ security problem with malicious guests (CVE-2010-3851).
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/cat/virt-ls.pod b/cat/virt-ls.pod
3efd08
index de02a473d..307e79395 100644
3efd08
--- a/cat/virt-ls.pod
3efd08
+++ b/cat/virt-ls.pod
3efd08
@@ -355,8 +355,8 @@ L</RECURSIVE LONG LISTING> above.
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/cat/virt-tail.pod b/cat/virt-tail.pod
3efd08
index f00384f5d..a804f4cf3 100644
3efd08
--- a/cat/virt-tail.pod
3efd08
+++ b/cat/virt-tail.pod
3efd08
@@ -126,8 +126,8 @@ security problem with malicious guests (CVE-2010-3851).
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/common/options/decrypt.c b/common/options/decrypt.c
3efd08
index 3511d9fe9..683cf5ed4 100644
3efd08
--- a/common/options/decrypt.c
3efd08
+++ b/common/options/decrypt.c
3efd08
@@ -86,7 +86,13 @@ inspect_do_decrypt (guestfs_h *g, struct key_store *ks)
3efd08
       char mapname[32];
3efd08
       make_mapname (partitions[i], mapname, sizeof mapname);
3efd08
 
3efd08
-      CLEANUP_FREE_STRING_LIST char **keys = get_keys (ks, partitions[i]);
3efd08
+#ifdef GUESTFS_HAVE_LUKS_UUID
3efd08
+      CLEANUP_FREE char *uuid = guestfs_luks_uuid (g, partitions[i]);
3efd08
+#else
3efd08
+      const char *uuid = NULL;
3efd08
+#endif
3efd08
+
3efd08
+      CLEANUP_FREE_STRING_LIST char **keys = get_keys (ks, partitions[i], uuid);
3efd08
       assert (guestfs_int_count_strings (keys) > 0);
3efd08
 
3efd08
       /* Try each key in turn. */
3efd08
diff --git a/common/options/keys.c b/common/options/keys.c
3efd08
index 7c391acde..798315c2e 100644
3efd08
--- a/common/options/keys.c
3efd08
+++ b/common/options/keys.c
3efd08
@@ -126,7 +126,7 @@ read_first_line_from_file (const char *filename)
3efd08
  * keystore, ask the user.
3efd08
  */
3efd08
 char **
3efd08
-get_keys (struct key_store *ks, const char *device)
3efd08
+get_keys (struct key_store *ks, const char *device, const char *uuid)
3efd08
 {
3efd08
   size_t i, j, len;
3efd08
   char **r;
3efd08
@@ -148,7 +148,7 @@ get_keys (struct key_store *ks, const char *device)
3efd08
     for (i = 0; i < ks->nr_keys; ++i) {
3efd08
       struct key_store_key *key = &ks->keys[i];
3efd08
 
3efd08
-      if (STRNEQ (key->id, device))
3efd08
+      if (STRNEQ (key->id, device) && (uuid && STRNEQ (key->id, uuid)))
3efd08
         continue;
3efd08
 
3efd08
       switch (key->type) {
3efd08
diff --git a/common/options/options.h b/common/options/options.h
3efd08
index b83a92b06..9b7830220 100644
3efd08
--- a/common/options/options.h
3efd08
+++ b/common/options/options.h
3efd08
@@ -104,8 +104,8 @@ struct mp {
3efd08
 
3efd08
 /* A key in the key store. */
3efd08
 struct key_store_key {
3efd08
-  /* An ID for the device this key refers to.  It must be the libguestfs
3efd08
-   * device name.
3efd08
+  /* An ID for the device this key refers to.  It can be either the libguestfs
3efd08
+   * device name, or the UUID.
3efd08
    *
3efd08
    * There may be multiple matching devices in the list.
3efd08
    */
3efd08
@@ -150,7 +150,7 @@ extern void print_inspect_prompt (void);
3efd08
 
3efd08
 /* in key.c */
3efd08
 extern char *read_key (const char *param);
3efd08
-extern char **get_keys (struct key_store *ks, const char *device);
3efd08
+extern char **get_keys (struct key_store *ks, const char *device, const char *uuid);
3efd08
 extern struct key_store *key_store_add_from_selector (struct key_store *ks, const char *selector);
3efd08
 extern struct key_store *key_store_import_key (struct key_store *ks, const struct key_store_key *key);
3efd08
 extern void free_key_store (struct key_store *ks);
3efd08
diff --git a/customize/virt-customize.pod b/customize/virt-customize.pod
3efd08
index 491606591..5d92486a2 100644
3efd08
--- a/customize/virt-customize.pod
3efd08
+++ b/customize/virt-customize.pod
3efd08
@@ -141,8 +141,8 @@ security problem with malicious guests (CVE-2010-3851).
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/diff/virt-diff.pod b/diff/virt-diff.pod
3efd08
index 22658072d..e67d09101 100644
3efd08
--- a/diff/virt-diff.pod
3efd08
+++ b/diff/virt-diff.pod
3efd08
@@ -169,8 +169,8 @@ Display file sizes in human-readable format.
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/edit/virt-edit.pod b/edit/virt-edit.pod
3efd08
index 5a63cd05f..918fa66f2 100644
3efd08
--- a/edit/virt-edit.pod
3efd08
+++ b/edit/virt-edit.pod
3efd08
@@ -156,8 +156,8 @@ security problem with malicious guests (CVE-2010-3851).
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/fish/guestfish.pod b/fish/guestfish.pod
3efd08
index ccb57b159..f1fdf094d 100644
3efd08
--- a/fish/guestfish.pod
3efd08
+++ b/fish/guestfish.pod
3efd08
@@ -283,8 +283,8 @@ were found.
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/fuse/guestmount.pod b/fuse/guestmount.pod
3efd08
index d9e957b8b..3a02c087c 100644
3efd08
--- a/fuse/guestmount.pod
3efd08
+++ b/fuse/guestmount.pod
3efd08
@@ -249,8 +249,8 @@ mounted on the real virtual machine.
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/get-kernel/virt-get-kernel.pod b/get-kernel/virt-get-kernel.pod
3efd08
index f0ace2d6d..78fe66df4 100644
3efd08
--- a/get-kernel/virt-get-kernel.pod
3efd08
+++ b/get-kernel/virt-get-kernel.pod
3efd08
@@ -92,8 +92,8 @@ security problem with malicious guests (CVE-2010-3851).
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/inspector/virt-inspector.pod b/inspector/virt-inspector.pod
3efd08
index eac9dc3cd..625da876c 100644
3efd08
--- a/inspector/virt-inspector.pod
3efd08
+++ b/inspector/virt-inspector.pod
3efd08
@@ -117,8 +117,8 @@ ensure the format is always specified.
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/sparsify/virt-sparsify.pod b/sparsify/virt-sparsify.pod
3efd08
index cf7970a5f..0767d07e6 100644
3efd08
--- a/sparsify/virt-sparsify.pod
3efd08
+++ b/sparsify/virt-sparsify.pod
3efd08
@@ -233,8 +233,8 @@ See L</IN-PLACE SPARSIFICATION> below.
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/sysprep/virt-sysprep.pod b/sysprep/virt-sysprep.pod
3efd08
index d7ad7ee33..b38c76c70 100644
3efd08
--- a/sysprep/virt-sysprep.pod
3efd08
+++ b/sysprep/virt-sysprep.pod
3efd08
@@ -189,8 +189,8 @@ security problem with malicious guests (CVE-2010-3851).
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
diff --git a/v2v/virt-v2v.pod b/v2v/virt-v2v.pod
3efd08
index 8c2867814..25041d0ec 100644
3efd08
--- a/v2v/virt-v2v.pod
3efd08
+++ b/v2v/virt-v2v.pod
3efd08
@@ -337,8 +337,8 @@ through VDDK.
3efd08
 =item B<--key> SELECTOR
3efd08
 
3efd08
 Specify a key for LUKS, to automatically open a LUKS device when using
3efd08
-the inspection.  C<ID> must be the libguestfs device name of the LUKS
3efd08
-device.
3efd08
+the inspection.  C<ID> can be either the libguestfs device name, or
3efd08
+the UUID of the LUKS device.
3efd08
 
3efd08
 =over 4
3efd08
 
3efd08
-- 
da373f
2.18.4
3efd08