render / rpms / libvirt

Forked from rpms/libvirt 5 months ago
Clone
d76c62
From 2d27c71da092e9232c2d79738a431c04db649a96 Mon Sep 17 00:00:00 2001
d76c62
Message-Id: <2d27c71da092e9232c2d79738a431c04db649a96@dist-git>
d76c62
From: Peter Krempa <pkrempa@redhat.com>
d76c62
Date: Mon, 30 Mar 2020 17:21:46 +0200
d76c62
Subject: [PATCH] qemuBlockStorageSourceGetURI: Pass through query component
d76c62
MIME-Version: 1.0
d76c62
Content-Type: text/plain; charset=UTF-8
d76c62
Content-Transfer-Encoding: 8bit
d76c62
d76c62
If the storage source has the query part set, format it in the output.
d76c62
d76c62
Signed-off-by: Peter Krempa <pkrempa@redhat.com>
d76c62
Reviewed-by: Ján Tomko <jtomko@redhat.com>
d76c62
(cherry picked from commit 216860dd8b93c7da4d625055cf353e0eedda6093)
d76c62
https://bugzilla.redhat.com/show_bug.cgi?id=1804750
d76c62
Message-Id: <832f573fd69341b7d730925c9df5b23e5f168408.1585581552.git.pkrempa@redhat.com>
d76c62
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
d76c62
---
d76c62
 src/qemu/qemu_block.c                                    | 2 ++
d76c62
 src/qemu/qemu_domain.c                                   | 9 +++++++++
d76c62
 tests/qemuxml2argvdata/disk-cdrom-network.args           | 4 ++--
d76c62
 .../disk-cdrom-network.x86_64-2.12.0.args                | 4 ++--
d76c62
 .../disk-cdrom-network.x86_64-latest.args                | 3 ++-
d76c62
 tests/qemuxml2argvdata/disk-cdrom-network.xml            | 2 +-
d76c62
 .../disk-network-http.x86_64-latest.args                 | 5 +++--
d76c62
 7 files changed, 21 insertions(+), 8 deletions(-)
d76c62
d76c62
diff --git a/src/qemu/qemu_block.c b/src/qemu/qemu_block.c
d76c62
index e7577c1312..6790f05ff7 100644
d76c62
--- a/src/qemu/qemu_block.c
d76c62
+++ b/src/qemu/qemu_block.c
d76c62
@@ -437,6 +437,8 @@ qemuBlockStorageSourceGetURI(virStorageSourcePtr src)
d76c62
         }
d76c62
     }
d76c62
 
d76c62
+    uri->query = g_strdup(src->query);
d76c62
+
d76c62
     uri->server = g_strdup(src->hosts->name);
d76c62
 
d76c62
     return g_steal_pointer(&uri);
d76c62
diff --git a/src/qemu/qemu_domain.c b/src/qemu/qemu_domain.c
d76c62
index 4007b4dbda..bb28716ff0 100644
d76c62
--- a/src/qemu/qemu_domain.c
d76c62
+++ b/src/qemu/qemu_domain.c
d76c62
@@ -7107,6 +7107,15 @@ qemuDomainValidateStorageSource(virStorageSourcePtr src,
d76c62
         }
d76c62
     }
d76c62
 
d76c62
+    if (src->query &&
d76c62
+        (actualType != VIR_STORAGE_TYPE_NETWORK ||
d76c62
+         (src->protocol != VIR_STORAGE_NET_PROTOCOL_HTTPS &&
d76c62
+          src->protocol != VIR_STORAGE_NET_PROTOCOL_HTTP))) {
d76c62
+        virReportError(VIR_ERR_CONFIG_UNSUPPORTED, "%s",
d76c62
+                       _("query is supported only with HTTP(S) protocols"));
d76c62
+        return -1;
d76c62
+    }
d76c62
+
d76c62
     return 0;
d76c62
 }
d76c62
 
d76c62
diff --git a/tests/qemuxml2argvdata/disk-cdrom-network.args b/tests/qemuxml2argvdata/disk-cdrom-network.args
d76c62
index be19bad68a..81ff324a0f 100644
d76c62
--- a/tests/qemuxml2argvdata/disk-cdrom-network.args
d76c62
+++ b/tests/qemuxml2argvdata/disk-cdrom-network.args
d76c62
@@ -30,8 +30,8 @@ id=drive-ide0-0-0,readonly=on \
d76c62
 -drive file=ftps://host.name:990/url/path/file.iso,format=raw,if=none,\
d76c62
 id=drive-ide0-0-1,readonly=on \
d76c62
 -device ide-cd,bus=ide.0,unit=1,drive=drive-ide0-0-1,id=ide0-0-1 \
d76c62
--drive file=https://host.name:443/url/path/file.iso,format=raw,if=none,\
d76c62
-id=drive-ide0-1-0,readonly=on \
d76c62
+-drive 'file=https://host.name:443/url/path/file.iso?test=val,format=raw,\
d76c62
+if=none,id=drive-ide0-1-0,readonly=on' \
d76c62
 -device ide-cd,bus=ide.1,unit=0,drive=drive-ide0-1-0,id=ide0-1-0 \
d76c62
 -drive file=tftp://host.name:69/url/path/file.iso,format=raw,if=none,\
d76c62
 id=drive-ide0-1-1,readonly=on \
d76c62
diff --git a/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-2.12.0.args b/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-2.12.0.args
d76c62
index 1ece3d6f46..81f6b400aa 100644
d76c62
--- a/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-2.12.0.args
d76c62
+++ b/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-2.12.0.args
d76c62
@@ -32,8 +32,8 @@ id=drive-ide0-0-0,readonly=on \
d76c62
 -drive file=ftps://host.name:990/url/path/file.iso,format=raw,if=none,\
d76c62
 id=drive-ide0-0-1,readonly=on \
d76c62
 -device ide-cd,bus=ide.0,unit=1,drive=drive-ide0-0-1,id=ide0-0-1 \
d76c62
--drive file=https://host.name:443/url/path/file.iso,format=raw,if=none,\
d76c62
-id=drive-ide0-1-0,readonly=on \
d76c62
+-drive 'file=https://host.name:443/url/path/file.iso?test=val,format=raw,\
d76c62
+if=none,id=drive-ide0-1-0,readonly=on' \
d76c62
 -device ide-cd,bus=ide.1,unit=0,drive=drive-ide0-1-0,id=ide0-1-0 \
d76c62
 -drive file=tftp://host.name:69/url/path/file.iso,format=raw,if=none,\
d76c62
 id=drive-ide0-1-1,readonly=on \
d76c62
diff --git a/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-latest.args b/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-latest.args
d76c62
index 0b4ac07f07..2515b256d0 100644
d76c62
--- a/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-latest.args
d76c62
+++ b/tests/qemuxml2argvdata/disk-cdrom-network.x86_64-latest.args
d76c62
@@ -37,7 +37,8 @@ file=/tmp/lib/domain--1-QEMUGuest1/master-key.aes \
d76c62
 -blockdev '{"node-name":"libvirt-3-format","read-only":true,"driver":"raw",\
d76c62
 "file":"libvirt-3-storage"}' \
d76c62
 -device ide-cd,bus=ide.0,unit=1,drive=libvirt-3-format,id=ide0-0-1 \
d76c62
--blockdev '{"driver":"https","url":"https://host.name:443/url/path/file.iso",\
d76c62
+-blockdev '{"driver":"https",\
d76c62
+"url":"https://host.name:443/url/path/file.iso?test=val",\
d76c62
 "node-name":"libvirt-2-storage","auto-read-only":true,"discard":"unmap"}' \
d76c62
 -blockdev '{"node-name":"libvirt-2-format","read-only":true,"driver":"raw",\
d76c62
 "file":"libvirt-2-storage"}' \
d76c62
diff --git a/tests/qemuxml2argvdata/disk-cdrom-network.xml b/tests/qemuxml2argvdata/disk-cdrom-network.xml
d76c62
index 0bdc0e1883..44473f8ad4 100644
d76c62
--- a/tests/qemuxml2argvdata/disk-cdrom-network.xml
d76c62
+++ b/tests/qemuxml2argvdata/disk-cdrom-network.xml
d76c62
@@ -39,7 +39,7 @@
d76c62
     </disk>
d76c62
     <disk type='network' device='cdrom'>
d76c62
       <driver name='qemu' type='raw'/>
d76c62
-      <source protocol='https' name='/url/path/file.iso'>
d76c62
+      <source protocol='https' name='/url/path/file.iso' query='test=val'>
d76c62
         <host name='host.name' port='443'/>
d76c62
       </source>
d76c62
       <target dev='hdc' bus='ide'/>
d76c62
diff --git a/tests/qemuxml2argvdata/disk-network-http.x86_64-latest.args b/tests/qemuxml2argvdata/disk-network-http.x86_64-latest.args
d76c62
index 46aa5f23ce..d1bf0b9caa 100644
d76c62
--- a/tests/qemuxml2argvdata/disk-network-http.x86_64-latest.args
d76c62
+++ b/tests/qemuxml2argvdata/disk-network-http.x86_64-latest.args
d76c62
@@ -54,8 +54,9 @@ id=virtio-disk2 \
d76c62
 -object secret,id=libvirt-1-storage-httpcookie-secret0,\
d76c62
 data=DrPR9NA6GKJb7qi1KbjHaealKEMVtOWUl2h3yvO5lgIh6cyLHemmlg+h9fcgwREA,\
d76c62
 keyid=masterKey0,iv=AAECAwQFBgcICQoLDA0ODw==,format=base64 \
d76c62
--blockdev '{"driver":"https","url":"https://example.org:1234/test4.img",\
d76c62
-"sslverify":false,"cookie-secret":"libvirt-1-storage-httpcookie-secret0",\
d76c62
+-blockdev '{"driver":"https",\
d76c62
+"url":"https://example.org:1234/test4.img?par=val&other=ble","sslverify":false,\
d76c62
+"cookie-secret":"libvirt-1-storage-httpcookie-secret0",\
d76c62
 "node-name":"libvirt-1-storage","auto-read-only":true,"discard":"unmap"}' \
d76c62
 -blockdev '{"node-name":"libvirt-1-format","read-only":false,"driver":"raw",\
d76c62
 "file":"libvirt-1-storage"}' \
d76c62
-- 
d76c62
2.26.0
d76c62