|
|
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):
|