Blame SOURCES/bz1464933-2-fence_redfish-fail-invalid-cert.patch

2d8bb4
From 7aa3c50d1d02dd26bdeac99c49ada72f842d88e8 Mon Sep 17 00:00:00 2001
2d8bb4
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
2d8bb4
Date: Thu, 17 Jan 2019 16:52:52 +0100
2d8bb4
Subject: [PATCH] fence_redfish: fail when using invalid cert without
2d8bb4
 --ssl-insecure
2d8bb4
2d8bb4
---
2d8bb4
 agents/redfish/fence_redfish.py | 16 ++++++++++------
2d8bb4
 1 file changed, 10 insertions(+), 6 deletions(-)
2d8bb4
2d8bb4
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
2d8bb4
index 67ef67ab..5b719d4b 100644
2d8bb4
--- a/agents/redfish/fence_redfish.py
2d8bb4
+++ b/agents/redfish/fence_redfish.py
2d8bb4
@@ -6,6 +6,7 @@
2d8bb4
 
2d8bb4
 import sys
2d8bb4
 import re
2d8bb4
+import logging
2d8bb4
 import json
2d8bb4
 import requests
2d8bb4
 import atexit
2d8bb4
@@ -20,6 +21,9 @@ def get_power_status(conn, options):
2d8bb4
     if response['ret'] is False:
2d8bb4
         fail_usage("Couldn't get power information")
2d8bb4
     data = response['data']
2d8bb4
+
2d8bb4
+    logging.debug("PowerState is: " + data[u'PowerState'])
2d8bb4
+
2d8bb4
     if data[u'PowerState'].strip() == "Off":
2d8bb4
         return "off"
2d8bb4
     else:
2d8bb4
@@ -50,21 +54,21 @@ def set_power_status(conn, options):
2d8bb4
 def send_get_request(options, uri):
2d8bb4
     full_uri = "https://" + options["--ip"] + uri
2d8bb4
     try:
2d8bb4
-        resp = requests.get(full_uri, verify=False,
2d8bb4
+        resp = requests.get(full_uri, verify=not "--ssl-insecure" in options,
2d8bb4
                             auth=(options["--username"], options["--password"]))
2d8bb4
         data = resp.json()
2d8bb4
-    except:
2d8bb4
-        return {'ret': False}
2d8bb4
+    except Exception as e:
2d8bb4
+        fail_usage("Failed: send_get_request: " + str(e))
2d8bb4
     return {'ret': True, 'data': data}
2d8bb4
 
2d8bb4
 def send_post_request(options, uri, payload, headers):
2d8bb4
     full_uri = "https://" + options["--ip"] + uri
2d8bb4
     try:
2d8bb4
         requests.post(full_uri, data=json.dumps(payload),
2d8bb4
-                      headers=headers, verify=False,
2d8bb4
+                      headers=headers, verify=not "--ssl-insecure" in options,
2d8bb4
                       auth=(options["--username"], options["--password"]))
2d8bb4
-    except:
2d8bb4
-        return {'ret': False}
2d8bb4
+    except Exception as e:
2d8bb4
+        fail_usage("Failed: send_post_request: " + str(e))
2d8bb4
     return {'ret': True}
2d8bb4
 
2d8bb4
 def find_systems_resource(options):