-it ssh: Double quote ssh command which tests remote file exists
resolves: RHEL-12105
This commit is contained in:
parent
ac1270e705
commit
09f3b77799
@ -15,20 +15,6 @@ Signed-off-by: Laszlo Ersek <lersek@redhat.com>
|
|||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
1 file changed, 1 insertion(+), 1 deletion(-)
|
||||||
|
|
||||||
Submodule common 38e6988c..b636c3f2:
|
Submodule common 38e6988c..b636c3f2:
|
||||||
diff --git a/common/options/options.h b/common/options/options.h
|
|
||||||
index 94573ee0..94e8b9ee 100644
|
|
||||||
--- a/common/options/options.h
|
|
||||||
+++ b/common/options/options.h
|
|
||||||
@@ -169,7 +169,8 @@ extern struct matching_key *get_keys (struct key_store *ks, const char *device,
|
|
||||||
const char *uuid, size_t *nr_matches);
|
|
||||||
extern void free_keys (struct matching_key *keys, size_t nr_matches);
|
|
||||||
extern struct key_store *key_store_add_from_selector (struct key_store *ks, const char *selector);
|
|
||||||
-extern struct key_store *key_store_import_key (struct key_store *ks, const struct key_store_key *key);
|
|
||||||
+extern struct key_store *key_store_import_key (struct key_store *ks,
|
|
||||||
+ struct key_store_key *key);
|
|
||||||
extern bool key_store_requires_network (const struct key_store *ks);
|
|
||||||
extern void free_key_store (struct key_store *ks);
|
|
||||||
|
|
||||||
diff --git a/common/options/keys.c b/common/options/keys.c
|
diff --git a/common/options/keys.c b/common/options/keys.c
|
||||||
index 48f1bc7c..52b27369 100644
|
index 48f1bc7c..52b27369 100644
|
||||||
--- a/common/options/keys.c
|
--- a/common/options/keys.c
|
||||||
@ -150,3 +136,17 @@ index 48f1bc7c..52b27369 100644
|
|||||||
ks->keys[ks->nr_keys] = *key;
|
ks->keys[ks->nr_keys] = *key;
|
||||||
++ks->nr_keys;
|
++ks->nr_keys;
|
||||||
|
|
||||||
|
diff --git a/common/options/options.h b/common/options/options.h
|
||||||
|
index 94573ee0..94e8b9ee 100644
|
||||||
|
--- a/common/options/options.h
|
||||||
|
+++ b/common/options/options.h
|
||||||
|
@@ -169,7 +169,8 @@ extern struct matching_key *get_keys (struct key_store *ks, const char *device,
|
||||||
|
const char *uuid, size_t *nr_matches);
|
||||||
|
extern void free_keys (struct matching_key *keys, size_t nr_matches);
|
||||||
|
extern struct key_store *key_store_add_from_selector (struct key_store *ks, const char *selector);
|
||||||
|
-extern struct key_store *key_store_import_key (struct key_store *ks, const struct key_store_key *key);
|
||||||
|
+extern struct key_store *key_store_import_key (struct key_store *ks,
|
||||||
|
+ struct key_store_key *key);
|
||||||
|
extern bool key_store_requires_network (const struct key_store *ks);
|
||||||
|
extern void free_key_store (struct key_store *ks);
|
||||||
|
|
||||||
|
@ -0,0 +1,99 @@
|
|||||||
|
From 35c987dcaaca7eb546ca35875f94623cca68c8b4 Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Richard W.M. Jones" <rjones@redhat.com>
|
||||||
|
Date: Mon, 25 Sep 2023 14:14:18 +0100
|
||||||
|
Subject: [PATCH] types: Add gcaps_rtc_utc to record if the RTC is set to UTC
|
||||||
|
or localtime
|
||||||
|
|
||||||
|
Almost every Linux guest expects the motherboard Real Time Clock (RTC)
|
||||||
|
to be set to UTC and they adjust the time displayed based on their
|
||||||
|
timezone (which may be different for each user).
|
||||||
|
|
||||||
|
Most Windows guests expect the RTC to be set to the local time.
|
||||||
|
Windows can be configured to use a UTC clock. We can detect this by
|
||||||
|
looking at the Windows registry.
|
||||||
|
|
||||||
|
To cope with this difference we need to add a guestcaps flag based on
|
||||||
|
what we think the guest is expecting. (We might also use the source
|
||||||
|
hypervisor RTC setting, but it is not thought to be as reliable as
|
||||||
|
inspecting the guest.)
|
||||||
|
|
||||||
|
This change simply adds the flag to guestcaps, and sets it to always
|
||||||
|
true, so there is no change to the output.
|
||||||
|
|
||||||
|
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
(cherry picked from commit 69d73c251a71586c870bf0cb185107f80caee270)
|
||||||
|
---
|
||||||
|
convert/convert_linux.ml | 1 +
|
||||||
|
convert/convert_windows.ml | 1 +
|
||||||
|
lib/types.ml | 3 +++
|
||||||
|
lib/types.mli | 5 +++++
|
||||||
|
4 files changed, 10 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/convert/convert_linux.ml b/convert/convert_linux.ml
|
||||||
|
index 8d702084..bd54568b 100644
|
||||||
|
--- a/convert/convert_linux.ml
|
||||||
|
+++ b/convert/convert_linux.ml
|
||||||
|
@@ -220,6 +220,7 @@ let convert (g : G.guestfs) source inspect i_firmware _ keep_serial_console _ =
|
||||||
|
gcaps_arch = Utils.kvm_arch inspect.i_arch;
|
||||||
|
gcaps_arch_min_version = arch_min_version;
|
||||||
|
gcaps_virtio_1_0 = virtio_1_0;
|
||||||
|
+ gcaps_rtc_utc = true; (* almost all Linux expect RTC to be UTC *)
|
||||||
|
} in
|
||||||
|
|
||||||
|
guestcaps
|
||||||
|
diff --git a/convert/convert_windows.ml b/convert/convert_windows.ml
|
||||||
|
index 122d9546..7e3aa8d7 100644
|
||||||
|
--- a/convert/convert_windows.ml
|
||||||
|
+++ b/convert/convert_windows.ml
|
||||||
|
@@ -275,6 +275,7 @@ let convert (g : G.guestfs) _ inspect i_firmware block_driver _ static_ips =
|
||||||
|
gcaps_arch = Utils.kvm_arch inspect.i_arch;
|
||||||
|
gcaps_arch_min_version = 0;
|
||||||
|
gcaps_virtio_1_0 = virtio_win_installed.Inject_virtio_win.virtio_1_0;
|
||||||
|
+ gcaps_rtc_utc = true;
|
||||||
|
} in
|
||||||
|
|
||||||
|
guestcaps
|
||||||
|
diff --git a/lib/types.ml b/lib/types.ml
|
||||||
|
index 75c14fd4..d6f9a266 100644
|
||||||
|
--- a/lib/types.ml
|
||||||
|
+++ b/lib/types.ml
|
||||||
|
@@ -399,6 +399,7 @@ type guestcaps = {
|
||||||
|
gcaps_arch : string;
|
||||||
|
gcaps_arch_min_version : int;
|
||||||
|
gcaps_virtio_1_0 : bool;
|
||||||
|
+ gcaps_rtc_utc : bool;
|
||||||
|
}
|
||||||
|
and guestcaps_block_type = Virtio_blk | Virtio_SCSI | IDE
|
||||||
|
and guestcaps_net_type = Virtio_net | E1000 | RTL8139
|
||||||
|
@@ -429,6 +430,7 @@ let string_of_guestcaps gcaps =
|
||||||
|
gcaps_arch = %s\n\
|
||||||
|
gcaps_arch_min_version = %d\n\
|
||||||
|
gcaps_virtio_1_0 = %b\n\
|
||||||
|
+ gcaps_rtc_utc = %b\n\
|
||||||
|
"
|
||||||
|
(string_of_block_type gcaps.gcaps_block_bus)
|
||||||
|
(string_of_net_type gcaps.gcaps_net_bus)
|
||||||
|
@@ -440,6 +442,7 @@ let string_of_guestcaps gcaps =
|
||||||
|
gcaps.gcaps_arch
|
||||||
|
gcaps.gcaps_arch_min_version
|
||||||
|
gcaps.gcaps_virtio_1_0
|
||||||
|
+ gcaps.gcaps_rtc_utc
|
||||||
|
|
||||||
|
type target_buses = {
|
||||||
|
target_virtio_blk_bus : target_bus_slot array;
|
||||||
|
diff --git a/lib/types.mli b/lib/types.mli
|
||||||
|
index 65ef2e35..3446bb64 100644
|
||||||
|
--- a/lib/types.mli
|
||||||
|
+++ b/lib/types.mli
|
||||||
|
@@ -277,6 +277,11 @@ type guestcaps = {
|
||||||
|
gcaps_virtio_1_0 : bool;
|
||||||
|
(** The guest supports the virtio devices that it does at the virtio-1.0
|
||||||
|
protocol level. *)
|
||||||
|
+
|
||||||
|
+ gcaps_rtc_utc : bool;
|
||||||
|
+ (** Is the RTC set to UTC ([true]) or localtime ([false])? For
|
||||||
|
+ Linux guests this is always true. For Windows we find out
|
||||||
|
+ what the guest is expecting by looking at the registry. *)
|
||||||
|
}
|
||||||
|
(** Guest capabilities after conversion. eg. Was virtio found or installed? *)
|
||||||
|
|
@ -0,0 +1,28 @@
|
|||||||
|
From 6964d1efbea560918c07bf99dcac81549947aadf Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Richard W.M. Jones" <rjones@redhat.com>
|
||||||
|
Date: Mon, 25 Sep 2023 14:31:17 +0100
|
||||||
|
Subject: [PATCH] -o kubevirt: Add comment about future support for clock =
|
||||||
|
localtime
|
||||||
|
|
||||||
|
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
(cherry picked from commit dfb44983a801fb57016298c79db6271262f78455)
|
||||||
|
---
|
||||||
|
output/create_kubevirt_yaml.ml | 5 +++++
|
||||||
|
1 file changed, 5 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/output/create_kubevirt_yaml.ml b/output/create_kubevirt_yaml.ml
|
||||||
|
index 689555e4..e3a3f422 100644
|
||||||
|
--- a/output/create_kubevirt_yaml.ml
|
||||||
|
+++ b/output/create_kubevirt_yaml.ml
|
||||||
|
@@ -54,6 +54,11 @@ let create_kubevirt_yaml source inspect
|
||||||
|
"pit", Assoc [ "tickPolicy", String "delay" ];
|
||||||
|
"rtc", Assoc [ "tickPolicy", String "catchup" ];
|
||||||
|
];
|
||||||
|
+ (* XXX Note that we may need to set "localtime" here
|
||||||
|
+ * depending on guestcaps.gcaps_rtc_utc. However that
|
||||||
|
+ * requires the following PR to be merged in Kubevirt:
|
||||||
|
+ * https://github.com/kubevirt/kubevirt/pull/9587
|
||||||
|
+ *)
|
||||||
|
"utc", List []
|
||||||
|
]
|
||||||
|
)
|
31
0023-output-create_libvirt_xml.ml-Refactor-os_section.patch
Normal file
31
0023-output-create_libvirt_xml.ml-Refactor-os_section.patch
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
From 3e6b4edc09972f311e2561fbac101f2a23001396 Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Richard W.M. Jones" <rjones@redhat.com>
|
||||||
|
Date: Mon, 25 Sep 2023 16:58:35 +0100
|
||||||
|
Subject: [PATCH] output/create_libvirt_xml.ml: Refactor os_section
|
||||||
|
|
||||||
|
Minor refactoring of how <os> section is generated in XML output.
|
||||||
|
There is no change in the output.
|
||||||
|
|
||||||
|
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
(cherry picked from commit baaeead927eb72e78c7b09fd285427e9b048ee31)
|
||||||
|
---
|
||||||
|
output/create_libvirt_xml.ml | 4 ++--
|
||||||
|
1 file changed, 2 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/output/create_libvirt_xml.ml b/output/create_libvirt_xml.ml
|
||||||
|
index 964acd25..12586fde 100644
|
||||||
|
--- a/output/create_libvirt_xml.ml
|
||||||
|
+++ b/output/create_libvirt_xml.ml
|
||||||
|
@@ -292,10 +292,10 @@ let create_libvirt_xml ?pool source inspect
|
||||||
|
e "nvram" ["template", vars_template] [] ] in
|
||||||
|
|
||||||
|
List.push_back_list os loader;
|
||||||
|
- !os in
|
||||||
|
+ e "os" [] !os in
|
||||||
|
|
||||||
|
List.push_back_list body [
|
||||||
|
- e "os" [] os_section;
|
||||||
|
+ os_section;
|
||||||
|
|
||||||
|
e "on_poweroff" [] [PCData "destroy"];
|
||||||
|
e "on_reboot" [] [PCData "restart"];
|
@ -0,0 +1,44 @@
|
|||||||
|
From f6b05e26cf6622d1010122b56848511b1ecd660e Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Richard W.M. Jones" <rjones@redhat.com>
|
||||||
|
Date: Mon, 25 Sep 2023 14:35:37 +0100
|
||||||
|
Subject: [PATCH] -o libvirt: Add <clock offset="utc|localtime"/> to libvirt
|
||||||
|
XML
|
||||||
|
|
||||||
|
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
(cherry picked from commit 93b86b8634428c1e3210d10cffa548ee5473418a)
|
||||||
|
---
|
||||||
|
output/create_libvirt_xml.ml | 6 ++++++
|
||||||
|
tests/test-v2v-i-ova.xml | 1 +
|
||||||
|
2 files changed, 7 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/output/create_libvirt_xml.ml b/output/create_libvirt_xml.ml
|
||||||
|
index 12586fde..30119d13 100644
|
||||||
|
--- a/output/create_libvirt_xml.ml
|
||||||
|
+++ b/output/create_libvirt_xml.ml
|
||||||
|
@@ -294,8 +294,14 @@ let create_libvirt_xml ?pool source inspect
|
||||||
|
List.push_back_list os loader;
|
||||||
|
e "os" [] !os in
|
||||||
|
|
||||||
|
+ (* The <clock> section. *)
|
||||||
|
+ let clock_section =
|
||||||
|
+ let offset = if guestcaps.gcaps_rtc_utc then "utc" else "localtime" in
|
||||||
|
+ e "clock" [ "offset", offset ] [] in
|
||||||
|
+
|
||||||
|
List.push_back_list body [
|
||||||
|
os_section;
|
||||||
|
+ clock_section;
|
||||||
|
|
||||||
|
e "on_poweroff" [] [PCData "destroy"];
|
||||||
|
e "on_reboot" [] [PCData "restart"];
|
||||||
|
diff --git a/tests/test-v2v-i-ova.xml b/tests/test-v2v-i-ova.xml
|
||||||
|
index e5907ea1..a41827bf 100644
|
||||||
|
--- a/tests/test-v2v-i-ova.xml
|
||||||
|
+++ b/tests/test-v2v-i-ova.xml
|
||||||
|
@@ -18,6 +18,7 @@
|
||||||
|
<os>
|
||||||
|
<type arch='x86_64' machine='q35'>hvm</type>
|
||||||
|
</os>
|
||||||
|
+ <clock offset='utc'/>
|
||||||
|
<on_poweroff>destroy</on_poweroff>
|
||||||
|
<on_reboot>restart</on_reboot>
|
||||||
|
<on_crash>restart</on_crash>
|
@ -0,0 +1,28 @@
|
|||||||
|
From dff314e22ba2d5666ba6a4f3440a7c9e1a658bb3 Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Richard W.M. Jones" <rjones@redhat.com>
|
||||||
|
Date: Mon, 25 Sep 2023 14:41:58 +0100
|
||||||
|
Subject: [PATCH] -o qemu: Set -rtc base=localtime when guest expects RTC set
|
||||||
|
to localtime
|
||||||
|
|
||||||
|
I didn't set the -rtc flag in the normal (UTC) case as that is the
|
||||||
|
default.
|
||||||
|
|
||||||
|
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
(cherry picked from commit 482d75bbe5cd242576cf3f8cb9062d13d511871e)
|
||||||
|
---
|
||||||
|
output/output_qemu.ml | 2 ++
|
||||||
|
1 file changed, 2 insertions(+)
|
||||||
|
|
||||||
|
diff --git a/output/output_qemu.ml b/output/output_qemu.ml
|
||||||
|
index ae93fb89..ad3eb897 100644
|
||||||
|
--- a/output/output_qemu.ml
|
||||||
|
+++ b/output/output_qemu.ml
|
||||||
|
@@ -161,6 +161,8 @@ module QEMU = struct
|
||||||
|
arg_list "-device" ["vmgenid"; sprintf "guid=%s" genid; "id=vmgenid0"]
|
||||||
|
);
|
||||||
|
|
||||||
|
+ if not guestcaps.gcaps_rtc_utc then arg "-rtc" "base=localtime";
|
||||||
|
+
|
||||||
|
arg_list "-machine" (machine_str ::
|
||||||
|
(if smm then ["smm=on"] else []) @
|
||||||
|
["accel=kvm:tcg"]);
|
@ -0,0 +1,89 @@
|
|||||||
|
From e7fe97447e5abb1f3343dde1710b0cffdd443e00 Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Richard W.M. Jones" <rjones@redhat.com>
|
||||||
|
Date: Mon, 25 Sep 2023 15:00:12 +0100
|
||||||
|
Subject: [PATCH] convert: Find out if Windows guest is expecting RTC set to
|
||||||
|
UTC
|
||||||
|
|
||||||
|
Read HKLM\SYSTEM\CurrentControlSet\Control\TimeZoneInformation key
|
||||||
|
"RealTimeIsUniversal" to see if the Windows guest is expecting RTC
|
||||||
|
set to localtime (not present) or UTC (present and set to 1).
|
||||||
|
|
||||||
|
See: https://wiki.archlinux.org/title/System_time#UTC_in_Microsoft_Windows
|
||||||
|
See: https://listman.redhat.com/archives/libguestfs/2023-September/thread.html#32556
|
||||||
|
Reported-by: Lee Garrett
|
||||||
|
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
(cherry picked from commit 5f58def90a4485627e8207782165db5a2899b72a)
|
||||||
|
---
|
||||||
|
convert/convert_windows.ml | 38 +++++++++++++++++++++++++++++++++++++-
|
||||||
|
tests/test-v2v-i-ova.xml | 2 +-
|
||||||
|
2 files changed, 38 insertions(+), 2 deletions(-)
|
||||||
|
|
||||||
|
diff --git a/convert/convert_windows.ml b/convert/convert_windows.ml
|
||||||
|
index 7e3aa8d7..34cf341b 100644
|
||||||
|
--- a/convert/convert_windows.ml
|
||||||
|
+++ b/convert/convert_windows.ml
|
||||||
|
@@ -103,6 +103,42 @@ let convert (g : G.guestfs) _ inspect i_firmware block_driver _ static_ips =
|
||||||
|
(* If the Windows guest has AV installed. *)
|
||||||
|
let has_antivirus = Windows.detect_antivirus inspect in
|
||||||
|
|
||||||
|
+ (* Does the guest expect the RTC to be set to UTC or localtime?
|
||||||
|
+ * See https://wiki.archlinux.org/title/System_time#UTC_in_Microsoft_Windows
|
||||||
|
+ * Note this might be a QWORD on 64 bit Windows instances.
|
||||||
|
+ *)
|
||||||
|
+ let rtc_utc =
|
||||||
|
+ Registry.with_hive_readonly g inspect.i_windows_system_hive
|
||||||
|
+ (fun reg ->
|
||||||
|
+ try
|
||||||
|
+ let key_path = [ "Control"; "TimeZoneInformation" ] in
|
||||||
|
+ let path = inspect.i_windows_current_control_set :: key_path in
|
||||||
|
+ let node =
|
||||||
|
+ match Registry.get_node reg path with
|
||||||
|
+ | None -> raise Not_found
|
||||||
|
+ | Some node -> node in
|
||||||
|
+ let valueh = g#hivex_node_get_value node "RealTimeIsUniversal" in
|
||||||
|
+ if valueh = 0L then raise Not_found;
|
||||||
|
+ let t = g#hivex_value_type valueh in
|
||||||
|
+ let data = g#hivex_value_value valueh in
|
||||||
|
+ let is_utc =
|
||||||
|
+ match t with
|
||||||
|
+ | 0_L (* REG_NONE *) -> false (* localtime *)
|
||||||
|
+ | 4_L (* REG_DWORD *) -> data = "\001\000\000\000"
|
||||||
|
+ | 11_L (* REG_QWORD *) -> data = "\001\000\000\000\000\000\000\000"
|
||||||
|
+ | _ (* who knows ... *) ->
|
||||||
|
+ warning (f_"unknown CurrentControlSet\\Control\\\
|
||||||
|
+ TimeZoneInformation key RealTimeIsUniversal \
|
||||||
|
+ type 0x%Lx, assuming RTC set to UTC") t;
|
||||||
|
+ true in
|
||||||
|
+ is_utc
|
||||||
|
+ with Not_found ->
|
||||||
|
+ (* If the key is not found then by default we assume
|
||||||
|
+ * that Windows is expecting the RTC to be set to localtime.
|
||||||
|
+ *)
|
||||||
|
+ false
|
||||||
|
+ ) in
|
||||||
|
+
|
||||||
|
(* Open the software hive (readonly) and find the Xen PV uninstaller,
|
||||||
|
* if it exists.
|
||||||
|
*)
|
||||||
|
@@ -275,7 +311,7 @@ let convert (g : G.guestfs) _ inspect i_firmware block_driver _ static_ips =
|
||||||
|
gcaps_arch = Utils.kvm_arch inspect.i_arch;
|
||||||
|
gcaps_arch_min_version = 0;
|
||||||
|
gcaps_virtio_1_0 = virtio_win_installed.Inject_virtio_win.virtio_1_0;
|
||||||
|
- gcaps_rtc_utc = true;
|
||||||
|
+ gcaps_rtc_utc = rtc_utc;
|
||||||
|
} in
|
||||||
|
|
||||||
|
guestcaps
|
||||||
|
diff --git a/tests/test-v2v-i-ova.xml b/tests/test-v2v-i-ova.xml
|
||||||
|
index a41827bf..fa7b4dbf 100644
|
||||||
|
--- a/tests/test-v2v-i-ova.xml
|
||||||
|
+++ b/tests/test-v2v-i-ova.xml
|
||||||
|
@@ -18,7 +18,7 @@
|
||||||
|
<os>
|
||||||
|
<type arch='x86_64' machine='q35'>hvm</type>
|
||||||
|
</os>
|
||||||
|
- <clock offset='utc'/>
|
||||||
|
+ <clock offset='localtime'/>
|
||||||
|
<on_poweroff>destroy</on_poweroff>
|
||||||
|
<on_reboot>restart</on_reboot>
|
||||||
|
<on_crash>restart</on_crash>
|
@ -0,0 +1,38 @@
|
|||||||
|
From 450e6c712b65eed91427fb9ac8c8e19b4e8eb9ad Mon Sep 17 00:00:00 2001
|
||||||
|
From: "Richard W.M. Jones" <rjones@redhat.com>
|
||||||
|
Date: Mon, 2 Oct 2023 10:00:10 +0100
|
||||||
|
Subject: [PATCH] -it ssh: Double quote ssh command which tests remote file
|
||||||
|
exists
|
||||||
|
|
||||||
|
Double quoting was removed in
|
||||||
|
commit e2af12ba69c4463bb73d30db63290a887cdd41eb ("input: -i vmx:
|
||||||
|
Remove support for openssh scp < 8.8", Nov 2021). However it should
|
||||||
|
only have been removed from scp commands, not for this ssh command
|
||||||
|
where it is still required.
|
||||||
|
|
||||||
|
See: https://github.com/libguestfs/virt-v2v/issues/35
|
||||||
|
Thanks: Laszlo Ersek for diagnosis and suggesting the fix
|
||||||
|
Reported-by: Bill Sanders
|
||||||
|
Reviewed-by: Laszlo Ersek <lersek@redhat.com>
|
||||||
|
(cherry picked from commit 22c5b98ab78c734b478c26e14ee62e2a065aaa0c)
|
||||||
|
---
|
||||||
|
input/parse_domain_from_vmx.ml | 6 +++++-
|
||||||
|
1 file changed, 5 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
|
diff --git a/input/parse_domain_from_vmx.ml b/input/parse_domain_from_vmx.ml
|
||||||
|
index 15ee093f..2e75e785 100644
|
||||||
|
--- a/input/parse_domain_from_vmx.ml
|
||||||
|
+++ b/input/parse_domain_from_vmx.ml
|
||||||
|
@@ -97,7 +97,11 @@ let remote_file_exists uri path =
|
||||||
|
| None -> ""
|
||||||
|
| Some user -> quote user ^ "@")
|
||||||
|
(quote (server_of_uri uri))
|
||||||
|
- (quote path) in
|
||||||
|
+ (* Double quoting is necessary for 'ssh', first to protect
|
||||||
|
+ * from the local shell, second to protect from the remote
|
||||||
|
+ * shell. https://github.com/libguestfs/virt-v2v/issues/35#issuecomment-1741730963
|
||||||
|
+ *)
|
||||||
|
+ (quote (quote path)) in
|
||||||
|
if verbose () then
|
||||||
|
eprintf "%s\n%!" cmd;
|
||||||
|
Sys.command cmd = 0
|
@ -7,7 +7,7 @@ set -e
|
|||||||
# ./copy-patches.sh
|
# ./copy-patches.sh
|
||||||
|
|
||||||
project=virt-v2v
|
project=virt-v2v
|
||||||
rhel_version=9.3
|
rhel_version=9.4
|
||||||
|
|
||||||
# Check we're in the right directory.
|
# Check we're in the right directory.
|
||||||
if [ ! -f $project.spec ]; then
|
if [ ! -f $project.spec ]; then
|
||||||
|
@ -16,7 +16,7 @@
|
|||||||
Name: virt-v2v
|
Name: virt-v2v
|
||||||
Epoch: 1
|
Epoch: 1
|
||||||
Version: 2.3.4
|
Version: 2.3.4
|
||||||
Release: 5%{?dist}
|
Release: 6%{?dist}
|
||||||
Summary: Convert a virtual machine to run on KVM
|
Summary: Convert a virtual machine to run on KVM
|
||||||
|
|
||||||
License: GPLv2+
|
License: GPLv2+
|
||||||
@ -56,6 +56,13 @@ Patch0017: 0017-test-data-phony-guests-fix-prerequisite-list-of-fedo.patch
|
|||||||
Patch0018: 0018-lib-utils-fix-typo.patch
|
Patch0018: 0018-lib-utils-fix-typo.patch
|
||||||
Patch0019: 0019-lib-utils-make-chown_for_libvirt_rhbz_1045069-fail-h.patch
|
Patch0019: 0019-lib-utils-make-chown_for_libvirt_rhbz_1045069-fail-h.patch
|
||||||
Patch0020: 0020-docs-virt-v2v-document-libvirt-system-instance-start.patch
|
Patch0020: 0020-docs-virt-v2v-document-libvirt-system-instance-start.patch
|
||||||
|
Patch0021: 0021-types-Add-gcaps_rtc_utc-to-record-if-the-RTC-is-set-.patch
|
||||||
|
Patch0022: 0022-o-kubevirt-Add-comment-about-future-support-for-cloc.patch
|
||||||
|
Patch0023: 0023-output-create_libvirt_xml.ml-Refactor-os_section.patch
|
||||||
|
Patch0024: 0024-o-libvirt-Add-clock-offset-utc-localtime-to-libvirt-.patch
|
||||||
|
Patch0025: 0025-o-qemu-Set-rtc-base-localtime-when-guest-expects-RTC.patch
|
||||||
|
Patch0026: 0026-convert-Find-out-if-Windows-guest-is-expecting-RTC-s.patch
|
||||||
|
Patch0027: 0027-it-ssh-Double-quote-ssh-command-which-tests-remote-f.patch
|
||||||
|
|
||||||
%if !0%{?rhel}
|
%if !0%{?rhel}
|
||||||
# libguestfs hasn't been built on i686 for a while since there is no
|
# libguestfs hasn't been built on i686 for a while since there is no
|
||||||
@ -359,6 +366,10 @@ make -C tests TESTS=test-v2v-fedora-luks-on-lvm-conversion.sh check
|
|||||||
|
|
||||||
|
|
||||||
%changelog
|
%changelog
|
||||||
|
* Fri Nov 10 2023 Richard W.M. Jones <rjones@redhat.com> - 1:2.3.4-6
|
||||||
|
- -it ssh: Double quote ssh command which tests remote file exists
|
||||||
|
resolves: RHEL-12105
|
||||||
|
|
||||||
* Mon Jul 03 2023 Laszlo Ersek <lersek@redhat.com> - 1:2.3.4-5
|
* Mon Jul 03 2023 Laszlo Ersek <lersek@redhat.com> - 1:2.3.4-5
|
||||||
- improve UX when running as root and we can't chown v2v tmpdir or socks
|
- improve UX when running as root and we can't chown v2v tmpdir or socks
|
||||||
- make the appliance kernel UP in %check, for working around RHBZ#2216496
|
- make the appliance kernel UP in %check, for working around RHBZ#2216496
|
||||||
|
Loading…
Reference in New Issue
Block a user