Blame SOURCES/bz1793738-fence_vmware_rest-2-support-utf-8-vm-names.patch

3bc0dd
From 80aea3942aaca881349230a32b5dcc06c57de98a Mon Sep 17 00:00:00 2001
3bc0dd
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
3bc0dd
Date: Tue, 19 May 2020 15:10:16 +0200
3bc0dd
Subject: [PATCH] fence_vmware_rest: support UTF-8 VM names
3bc0dd
3bc0dd
---
3bc0dd
 agents/vmware_rest/fence_vmware_rest.py | 7 +++++--
3bc0dd
 1 file changed, 5 insertions(+), 2 deletions(-)
3bc0dd
3bc0dd
diff --git a/agents/vmware_rest/fence_vmware_rest.py b/agents/vmware_rest/fence_vmware_rest.py
3bc0dd
index 675de246..a038a096 100644
3bc0dd
--- a/agents/vmware_rest/fence_vmware_rest.py
3bc0dd
+++ b/agents/vmware_rest/fence_vmware_rest.py
3bc0dd
@@ -8,11 +8,14 @@
3bc0dd
 from fencing import *
3bc0dd
 from fencing import fail, run_delay, EC_LOGIN_DENIED, EC_STATUS
3bc0dd
 
3bc0dd
+if sys.version_info[0] > 2: import urllib.parse as urllib
3bc0dd
+else: import urllib
3bc0dd
+
3bc0dd
 state = {"POWERED_ON": "on", 'POWERED_OFF': "off", 'SUSPENDED': "off"}
3bc0dd
 
3bc0dd
 def get_power_status(conn, options):
3bc0dd
 	try:
3bc0dd
-		res = send_command(conn, "vcenter/vm?filter.names={}".format(options["--plug"]))["value"]
3bc0dd
+		res = send_command(conn, "vcenter/vm?filter.names={}".format(urllib.quote(options["--plug"])))["value"]
3bc0dd
 	except Exception as e:
3bc0dd
 		logging.debug("Failed: {}".format(e))
3bc0dd
 		fail(EC_STATUS)
3bc0dd
@@ -58,7 +61,7 @@ def get_list(conn, options):
3bc0dd
 			fail(EC_STATUS)
3bc0dd
 
3bc0dd
 	for r in res["value"]:
3bc0dd
-		outlets[r["name"]] = ("", state[r["power_state"]])
3bc0dd
+		outlets[r["name"].encode("UTF-8")] = ("", state[r["power_state"]])
3bc0dd
 
3bc0dd
 	return outlets
3bc0dd