55 lines
2.0 KiB
Diff
55 lines
2.0 KiB
Diff
|
|
From b1e1413077ee5bb9f0f5eed82cf6c629d7df4ebf Mon Sep 17 00:00:00 2001
|
||
|
|
From: Peter Krempa <pkrempa@redhat.com>
|
||
|
|
Date: Thu, 26 Nov 2020 19:07:03 +0100
|
||
|
|
Subject: [PATCH 07/16] qemu: command: Generate commandline of 'masterKey0'
|
||
|
|
secret via JSON
|
||
|
|
MIME-Version: 1.0
|
||
|
|
Content-Type: text/plain; charset=UTF-8
|
||
|
|
Content-Transfer-Encoding: 8bit
|
||
|
|
|
||
|
|
While the 'masterKey0' secret object will never be hotplugged we want to
|
||
|
|
generate it through JSON so that we'll be able to validate all
|
||
|
|
parameters of '-object' against the QAPI schema once 'object-add' is
|
||
|
|
qapified in qemu.
|
||
|
|
|
||
|
|
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
|
||
|
|
Reviewed-by: Ján Tomko <jtomko@redhat.com>
|
||
|
|
---
|
||
|
|
src/qemu/qemu_command.c | 12 ++++++++++--
|
||
|
|
1 file changed, 10 insertions(+), 2 deletions(-)
|
||
|
|
|
||
|
|
diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c
|
||
|
|
index d5d46c0892..6a861f3c8f 100644
|
||
|
|
--- a/src/qemu/qemu_command.c
|
||
|
|
+++ b/src/qemu/qemu_command.c
|
||
|
|
@@ -208,6 +208,7 @@ qemuBuildMasterKeyCommandLine(virCommandPtr cmd,
|
||
|
|
g_autofree char *alias = NULL;
|
||
|
|
g_autofree char *path = NULL;
|
||
|
|
g_auto(virBuffer) buf = VIR_BUFFER_INITIALIZER;
|
||
|
|
+ g_autoptr(virJSONValue) props = NULL;
|
||
|
|
|
||
|
|
/* If the -object secret does not exist, then just return. This just
|
||
|
|
* means the domain won't be able to use a secret master key and is
|
||
|
|
@@ -229,9 +230,16 @@ qemuBuildMasterKeyCommandLine(virCommandPtr cmd,
|
||
|
|
if (!(path = qemuDomainGetMasterKeyFilePath(priv->libDir)))
|
||
|
|
return -1;
|
||
|
|
|
||
|
|
+ if (qemuMonitorCreateObjectProps(&props, "secret", alias,
|
||
|
|
+ "s:format", "raw",
|
||
|
|
+ "s:file", path,
|
||
|
|
+ NULL) < 0)
|
||
|
|
+ return -1;
|
||
|
|
+
|
||
|
|
+ if (virQEMUBuildObjectCommandlineFromJSON(&buf, props) < 0)
|
||
|
|
+ return -1;
|
||
|
|
+
|
||
|
|
virCommandAddArg(cmd, "-object");
|
||
|
|
- virBufferAsprintf(&buf, "secret,id=%s,format=raw,file=", alias);
|
||
|
|
- virQEMUBuildBufferEscapeComma(&buf, path);
|
||
|
|
virCommandAddArgBuffer(cmd, &buf);
|
||
|
|
|
||
|
|
return 0;
|
||
|
|
--
|
||
|
|
2.27.0
|
||
|
|
|