Blame SOURCES/bz1666848-1-fence_redfish.patch

7f4c66
From 64e3f3ef4d0abefd2836fe015c87173310b1e130 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Mon, 3 Dec 2018 10:11:15 -0600
7f4c66
Subject: [PATCH 1/8] Add new fence agent for Redfish
7f4c66
7f4c66
- Agent works on all fence devices that implement the Redfish API specification
7f4c66
- Agent programatically finds the Systems Resouce URI if it's not provided
7f4c66
---
7f4c66
 agents/redfish/fence_redfish.py       | 151 +++++++++++++++++++++
7f4c66
 tests/data/metadata/fence_redfish.xml | 181 ++++++++++++++++++++++++++
7f4c66
 2 files changed, 332 insertions(+)
7f4c66
 create mode 100644 agents/redfish/fence_redfish.py
7f4c66
 create mode 100644 tests/data/metadata/fence_redfish.xml
7f4c66
7f4c66
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
7f4c66
new file mode 100644
7f4c66
index 00000000..df7cf8c2
7f4c66
--- /dev/null
7f4c66
+++ b/agents/redfish/fence_redfish.py
7f4c66
@@ -0,0 +1,151 @@
7f4c66
+#!@PYTHON@ -tt
7f4c66
+
7f4c66
+# Copyright (c) 2018 Dell Inc. or its subsidiaries. All Rights Reserved.
7f4c66
+
7f4c66
+# Fence agent for devices that support the Redfish API Specification.
7f4c66
+
7f4c66
+import sys
7f4c66
+import re
7f4c66
+import json
7f4c66
+import requests
7f4c66
+import atexit
7f4c66
+sys.path.append("@FENCEAGENTSLIBDIR@")
7f4c66
+
7f4c66
+from requests.packages.urllib3.exceptions import InsecureRequestWarning
7f4c66
+from fencing import *
7f4c66
+from fencing import fail_usage
7f4c66
+
7f4c66
+def get_power_status(conn, options):
7f4c66
+    uri = options["--systems-uri"]
7f4c66
+    response = send_get_request(options, uri)
7f4c66
+    if response['ret'] is False:
7f4c66
+        fail_usage("Couldn't get power information")
7f4c66
+    data = response['data']
7f4c66
+    if data[u'PowerState'].strip() == "On":
7f4c66
+        return "on"
7f4c66
+    else:
7f4c66
+        return "off"
7f4c66
+
7f4c66
+def set_power_status(conn, options):
7f4c66
+    action = {
7f4c66
+        'on' : "On",
7f4c66
+        'off': "ForceOff",
7f4c66
+        'reboot': "GracefulRestart"
7f4c66
+    }[options["--action"]]
7f4c66
+
7f4c66
+    payload = {'ResetType': action}
7f4c66
+    headers = {'content-type': 'application/json'}
7f4c66
+
7f4c66
+    # Search for 'Actions' key and extract URI from it
7f4c66
+    uri = options["--systems-uri"]
7f4c66
+    response = send_get_request(options, uri)
7f4c66
+    if response['ret'] is False:
7f4c66
+        return {'ret': False}
7f4c66
+    data = response['data']
7f4c66
+    uri = data["Actions"]["#ComputerSystem.Reset"]["target"]
7f4c66
+
7f4c66
+    response = send_post_request(options, uri, payload, headers)
7f4c66
+    if response['ret'] is False:
7f4c66
+        fail_usage("Error sending power command")
7f4c66
+    return
7f4c66
+
7f4c66
+def send_get_request(options, uri):
7f4c66
+    full_uri = "https://" + options["--ip"] + uri
7f4c66
+    try:
7f4c66
+        resp = requests.get(full_uri, verify=False,
7f4c66
+                            auth=(options["--username"], options["--password"]))
7f4c66
+        data = resp.json()
7f4c66
+    except:
7f4c66
+        return {'ret': False}
7f4c66
+    return {'ret': True, 'data': data}
7f4c66
+
7f4c66
+def send_post_request(options, uri, payload, headers):
7f4c66
+    full_uri = "https://" + options["--ip"] + uri
7f4c66
+    try:
7f4c66
+        requests.post(full_uri, data=json.dumps(payload),
7f4c66
+                      headers=headers, verify=False,
7f4c66
+                      auth=(options["--username"], options["--password"]))
7f4c66
+    except:
7f4c66
+        return {'ret': False}
7f4c66
+    return {'ret': True}
7f4c66
+
7f4c66
+def find_systems_resource(options):
7f4c66
+    uri = options["--redfish-uri"]
7f4c66
+    response = send_get_request(options, uri)
7f4c66
+    if response['ret'] is False:
7f4c66
+        return {'ret': False}
7f4c66
+    data = response['data']
7f4c66
+
7f4c66
+    if 'Systems' not in data:
7f4c66
+        # Systems resource not found"
7f4c66
+        return {'ret': False}
7f4c66
+    else:
7f4c66
+        uri = data["Systems"]["@odata.id"]
7f4c66
+        response = send_get_request(options, uri)
7f4c66
+        if response['ret'] is False:
7f4c66
+            return {'ret': False}
7f4c66
+        data = response['data']
7f4c66
+
7f4c66
+        # need to be able to handle more than one entry
7f4c66
+        for member in data[u'Members']:
7f4c66
+            system_uri = member[u'@odata.id']
7f4c66
+        return {'ret': True, 'uri': system_uri}
7f4c66
+
7f4c66
+def define_new_opts():
7f4c66
+    all_opt["redfish-uri"] = {
7f4c66
+        "getopt" : ":",
7f4c66
+        "longopt" : "redfish-uri",
7f4c66
+        "help" : "--redfish-uri=[uri]            Base or starting Redifsh URI",
7f4c66
+        "required" : "0",
7f4c66
+        "default" : "/redfish/v1",
7f4c66
+        "shortdesc" : "Base or starting Redfish URI",
7f4c66
+        "order": 1
7f4c66
+    }
7f4c66
+    all_opt["systems-uri"] = {
7f4c66
+        "getopt" : ":",
7f4c66
+        "longopt" : "systems-uri",
7f4c66
+        "help" : "--systems-uri=[uri]            Redfish Systems resource URI",
7f4c66
+        "required" : "0",
7f4c66
+        "shortdesc" : "Redfish Systems resource URI, i.e. /redfish/v1/Systems/System.Embedded.1",
7f4c66
+        "order": 1
7f4c66
+    }
7f4c66
+
7f4c66
+def main():
7f4c66
+    atexit.register(atexit_handler)
7f4c66
+    device_opt = ["ipaddr", "login", "passwd", "redfish-uri", "systems-uri", "ssl"]
7f4c66
+    define_new_opts()
7f4c66
+
7f4c66
+    opt = process_input(device_opt)
7f4c66
+
7f4c66
+    all_opt["ipport"]["default"] = "443"
7f4c66
+    options = check_input(device_opt, opt)
7f4c66
+
7f4c66
+    docs = {}
7f4c66
+    docs["shortdesc"] = "I/O Fencing agent for Redfish"
7f4c66
+    docs["longdesc"] = "fence_redfish is an I/O Fencing agent which can be used with \
7f4c66
+Out-of-Band controllers that support Redfish APIs. These controllers provide remote \
7f4c66
+access to control power on a server."
7f4c66
+    docs["vendorurl"] = "http://www.dmtf.org"
7f4c66
+    show_docs(options, docs)
7f4c66
+
7f4c66
+    ##
7f4c66
+    ## Operate the fencing device
7f4c66
+    ####
7f4c66
+
7f4c66
+    # Disable insecure-certificate-warning message
7f4c66
+    if "--ssl-insecure" in opt:
7f4c66
+        requests.packages.urllib3.disable_warnings(InsecureRequestWarning)
7f4c66
+
7f4c66
+    if "--systems-uri" not in opt:
7f4c66
+        # Systems URI not provided, find it
7f4c66
+        sysresult = find_systems_resource(options)
7f4c66
+        if sysresult['ret'] is False:
7f4c66
+            sys.exit(1)
7f4c66
+        else:
7f4c66
+            options["--systems-uri"] = sysresult["uri"]
7f4c66
+
7f4c66
+    result = fence_action(None, options, set_power_status, get_power_status, None)
7f4c66
+    sys.exit(result)
7f4c66
+
7f4c66
+if __name__ == "__main__":
7f4c66
+    main()
7f4c66
diff --git a/tests/data/metadata/fence_redfish.xml b/tests/data/metadata/fence_redfish.xml
7f4c66
new file mode 100644
7f4c66
index 00000000..43d447d0
7f4c66
--- /dev/null
7f4c66
+++ b/tests/data/metadata/fence_redfish.xml
7f4c66
@@ -0,0 +1,181 @@
7f4c66
+
7f4c66
+<resource-agent name="fence_redfish" shortdesc="I/O Fencing agent for Redfish" >
7f4c66
+<longdesc>fence_redfish is an I/O Fencing agent which can be used with Out-of-Band controllers that support Redfish APIs. These controllers provide remote access to control power on a server.</longdesc>
7f4c66
+<vendor-url>http://www.dmtf.org</vendor-url>
7f4c66
+<parameters>
7f4c66
+	<parameter name="ipport" unique="0" required="0">
7f4c66
+		<getopt mixed="-u, --ipport=[port]" />
7f4c66
+		<content type="integer" default="443"  />
7f4c66
+		<shortdesc lang="en">TCP/UDP port to use for connection with device</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="ssl_secure" unique="0" required="0">
7f4c66
+		<getopt mixed="--ssl-secure" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">SSL connection with verifying fence device's certificate</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="systems-uri" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="--systems-uri=[uri]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Redfish Systems resource URI, i.e. /redfish/v1/Systems/System.Embedded.1</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="action" unique="0" required="1">
7f4c66
+		<getopt mixed="-o, --action=[action]" />
7f4c66
+		<content type="string" default="reboot"  />
7f4c66
+		<shortdesc lang="en">Fencing Action</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="inet6_only" unique="0" required="0">
7f4c66
+		<getopt mixed="-6, --inet6-only" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Forces agent to use IPv6 addresses only</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="ipaddr" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-a, --ip=[ip]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">IP Address or Hostname</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="port" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-n, --plug=[ip]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">IP address or hostname of fencing device (together with --port-as-ip)</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="passwd_script" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-S, --password-script=[script]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Script to retrieve password</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="inet4_only" unique="0" required="0">
7f4c66
+		<getopt mixed="-4, --inet4-only" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Forces agent to use IPv4 addresses only</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="passwd" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-p, --password=[password]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Login password or passphrase</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="ssl" unique="0" required="0">
7f4c66
+		<getopt mixed="-z, --ssl" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">SSL connection</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="redfish-uri" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="--redfish-uri=[uri]" />
7f4c66
+		<content type="string" default="/redfish/v1"  />
7f4c66
+		<shortdesc lang="en">Base or starting Redfish URI</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="ssl_insecure" unique="0" required="0">
7f4c66
+		<getopt mixed="--ssl-insecure" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">SSL connection without verifying fence device's certificate</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="login" unique="0" required="1" deprecated="1">
7f4c66
+		<getopt mixed="-l, --username=[name]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Login Name</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="plug" unique="0" required="0" obsoletes="port">
7f4c66
+		<getopt mixed="-n, --plug=[ip]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">IP address or hostname of fencing device (together with --port-as-ip)</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="username" unique="0" required="1" obsoletes="login">
7f4c66
+		<getopt mixed="-l, --username=[name]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Login Name</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="redfish_uri" unique="0" required="0" obsoletes="redfish-uri">
7f4c66
+		<getopt mixed="--redfish-uri=[uri]" />
7f4c66
+		<content type="string" default="/redfish/v1"  />
7f4c66
+		<shortdesc lang="en">Base or starting Redfish URI</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="ip" unique="0" required="0" obsoletes="ipaddr">
7f4c66
+		<getopt mixed="-a, --ip=[ip]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">IP Address or Hostname</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="systems_uri" unique="0" required="0" obsoletes="systems-uri">
7f4c66
+		<getopt mixed="--systems-uri=[uri]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Redfish Systems resource URI, i.e. /redfish/v1/Systems/System.Embedded.1</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="password" unique="0" required="0" obsoletes="passwd">
7f4c66
+		<getopt mixed="-p, --password=[password]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Login password or passphrase</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="password_script" unique="0" required="0" obsoletes="passwd_script">
7f4c66
+		<getopt mixed="-S, --password-script=[script]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Script to retrieve password</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="verbose" unique="0" required="0">
7f4c66
+		<getopt mixed="-v, --verbose" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Verbose mode</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="debug" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-D, --debug-file=[debugfile]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Write debug information to given file</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="debug_file" unique="0" required="0" obsoletes="debug">
7f4c66
+		<getopt mixed="-D, --debug-file=[debugfile]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Write debug information to given file</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="version" unique="0" required="0">
7f4c66
+		<getopt mixed="-V, --version" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Display version information and exit</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="help" unique="0" required="0">
7f4c66
+		<getopt mixed="-h, --help" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Display help and exit</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="power_wait" unique="0" required="0">
7f4c66
+		<getopt mixed="--power-wait=[seconds]" />
7f4c66
+		<content type="second" default="0"  />
7f4c66
+		<shortdesc lang="en">Wait X seconds after issuing ON/OFF</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="login_timeout" unique="0" required="0">
7f4c66
+		<getopt mixed="--login-timeout=[seconds]" />
7f4c66
+		<content type="second" default="5"  />
7f4c66
+		<shortdesc lang="en">Wait X seconds for cmd prompt after login</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="power_timeout" unique="0" required="0">
7f4c66
+		<getopt mixed="--power-timeout=[seconds]" />
7f4c66
+		<content type="second" default="20"  />
7f4c66
+		<shortdesc lang="en">Test X seconds for status change after ON/OFF</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="delay" unique="0" required="0">
7f4c66
+		<getopt mixed="--delay=[seconds]" />
7f4c66
+		<content type="second" default="0"  />
7f4c66
+		<shortdesc lang="en">Wait X seconds before fencing is started</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="shell_timeout" unique="0" required="0">
7f4c66
+		<getopt mixed="--shell-timeout=[seconds]" />
7f4c66
+		<content type="second" default="3"  />
7f4c66
+		<shortdesc lang="en">Wait X seconds for cmd prompt after issuing command</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="port_as_ip" unique="0" required="0">
7f4c66
+		<getopt mixed="--port-as-ip" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Make "port/plug" to be an alias to IP address</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="retry_on" unique="0" required="0">
7f4c66
+		<getopt mixed="--retry-on=[attempts]" />
7f4c66
+		<content type="integer" default="1"  />
7f4c66
+		<shortdesc lang="en">Count of attempts to retry power on</shortdesc>
7f4c66
+	</parameter>
7f4c66
+</parameters>
7f4c66
+<actions>
7f4c66
+	<action name="on" automatic="0"/>
7f4c66
+	<action name="off" />
7f4c66
+	<action name="reboot" />
7f4c66
+	<action name="status" />
7f4c66
+	<action name="monitor" />
7f4c66
+	<action name="metadata" />
7f4c66
+	<action name="validate-all" />
7f4c66
+</actions>
7f4c66
+</resource-agent>
7f4c66
7f4c66
From 6921a34d64d098a7b1f32205e0be434438c36898 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Mon, 3 Dec 2018 10:46:52 -0600
7f4c66
Subject: [PATCH 2/8] Updated fence_redfish.xml with make xml-upload
7f4c66
7f4c66
---
7f4c66
 tests/data/metadata/fence_redfish.xml | 148 ++++++++++++++------------
7f4c66
 1 file changed, 79 insertions(+), 69 deletions(-)
7f4c66
7f4c66
diff --git a/tests/data/metadata/fence_redfish.xml b/tests/data/metadata/fence_redfish.xml
7f4c66
index 43d447d0..a39541e6 100644
7f4c66
--- a/tests/data/metadata/fence_redfish.xml
7f4c66
+++ b/tests/data/metadata/fence_redfish.xml
7f4c66
@@ -3,110 +3,115 @@
7f4c66
 <longdesc>fence_redfish is an I/O Fencing agent which can be used with Out-of-Band controllers that support Redfish APIs. These controllers provide remote access to control power on a server.</longdesc>
7f4c66
 <vendor-url>http://www.dmtf.org</vendor-url>
7f4c66
 <parameters>
7f4c66
-	<parameter name="ipport" unique="0" required="0">
7f4c66
-		<getopt mixed="-u, --ipport=[port]" />
7f4c66
-		<content type="integer" default="443"  />
7f4c66
-		<shortdesc lang="en">TCP/UDP port to use for connection with device</shortdesc>
7f4c66
-	</parameter>
7f4c66
-	<parameter name="ssl_secure" unique="0" required="0">
7f4c66
-		<getopt mixed="--ssl-secure" />
7f4c66
-		<content type="boolean"  />
7f4c66
-		<shortdesc lang="en">SSL connection with verifying fence device's certificate</shortdesc>
7f4c66
-	</parameter>
7f4c66
-	<parameter name="systems-uri" unique="0" required="0" deprecated="1">
7f4c66
-		<getopt mixed="--systems-uri=[uri]" />
7f4c66
-		<content type="string"  />
7f4c66
-		<shortdesc lang="en">Redfish Systems resource URI, i.e. /redfish/v1/Systems/System.Embedded.1</shortdesc>
7f4c66
-	</parameter>
7f4c66
 	<parameter name="action" unique="0" required="1">
7f4c66
 		<getopt mixed="-o, --action=[action]" />
7f4c66
 		<content type="string" default="reboot"  />
7f4c66
-		<shortdesc lang="en">Fencing Action</shortdesc>
7f4c66
+		<shortdesc lang="en">Fencing action</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="inet4_only" unique="0" required="0">
7f4c66
+		<getopt mixed="-4, --inet4-only" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Forces agent to use IPv4 addresses only</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="inet6_only" unique="0" required="0">
7f4c66
 		<getopt mixed="-6, --inet6-only" />
7f4c66
 		<content type="boolean"  />
7f4c66
 		<shortdesc lang="en">Forces agent to use IPv6 addresses only</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="ipaddr" unique="0" required="0" deprecated="1">
7f4c66
+	<parameter name="ip" unique="0" required="0" obsoletes="ipaddr">
7f4c66
 		<getopt mixed="-a, --ip=[ip]" />
7f4c66
 		<content type="string"  />
7f4c66
-		<shortdesc lang="en">IP Address or Hostname</shortdesc>
7f4c66
+		<shortdesc lang="en">IP address or hostname of fencing device</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="port" unique="0" required="0" deprecated="1">
7f4c66
-		<getopt mixed="-n, --plug=[ip]" />
7f4c66
+	<parameter name="ipaddr" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-a, --ip=[ip]" />
7f4c66
 		<content type="string"  />
7f4c66
-		<shortdesc lang="en">IP address or hostname of fencing device (together with --port-as-ip)</shortdesc>
7f4c66
+		<shortdesc lang="en">IP address or hostname of fencing device</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="passwd_script" unique="0" required="0" deprecated="1">
7f4c66
-		<getopt mixed="-S, --password-script=[script]" />
7f4c66
-		<content type="string"  />
7f4c66
-		<shortdesc lang="en">Script to retrieve password</shortdesc>
7f4c66
+	<parameter name="ipport" unique="0" required="0">
7f4c66
+		<getopt mixed="-u, --ipport=[port]" />
7f4c66
+		<content type="integer" default="443"  />
7f4c66
+		<shortdesc lang="en">TCP/UDP port to use for connection with device</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="inet4_only" unique="0" required="0">
7f4c66
-		<getopt mixed="-4, --inet4-only" />
7f4c66
-		<content type="boolean"  />
7f4c66
-		<shortdesc lang="en">Forces agent to use IPv4 addresses only</shortdesc>
7f4c66
+	<parameter name="login" unique="0" required="1" deprecated="1">
7f4c66
+		<getopt mixed="-l, --username=[name]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Login name</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="passwd" unique="0" required="0" deprecated="1">
7f4c66
 		<getopt mixed="-p, --password=[password]" />
7f4c66
 		<content type="string"  />
7f4c66
 		<shortdesc lang="en">Login password or passphrase</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="ssl" unique="0" required="0">
7f4c66
-		<getopt mixed="-z, --ssl" />
7f4c66
-		<content type="boolean"  />
7f4c66
-		<shortdesc lang="en">SSL connection</shortdesc>
7f4c66
-	</parameter>
7f4c66
-	<parameter name="redfish-uri" unique="0" required="0" deprecated="1">
7f4c66
-		<getopt mixed="--redfish-uri=[uri]" />
7f4c66
-		<content type="string" default="/redfish/v1"  />
7f4c66
-		<shortdesc lang="en">Base or starting Redfish URI</shortdesc>
7f4c66
+	<parameter name="passwd_script" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-S, --password-script=[script]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Script to run to retrieve password</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="ssl_insecure" unique="0" required="0">
7f4c66
-		<getopt mixed="--ssl-insecure" />
7f4c66
-		<content type="boolean"  />
7f4c66
-		<shortdesc lang="en">SSL connection without verifying fence device's certificate</shortdesc>
7f4c66
+	<parameter name="password" unique="0" required="0" obsoletes="passwd">
7f4c66
+		<getopt mixed="-p, --password=[password]" />
7f4c66
+		<content type="string"  />
7f4c66
+		<shortdesc lang="en">Login password or passphrase</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="login" unique="0" required="1" deprecated="1">
7f4c66
-		<getopt mixed="-l, --username=[name]" />
7f4c66
+	<parameter name="password_script" unique="0" required="0" obsoletes="passwd_script">
7f4c66
+		<getopt mixed="-S, --password-script=[script]" />
7f4c66
 		<content type="string"  />
7f4c66
-		<shortdesc lang="en">Login Name</shortdesc>
7f4c66
+		<shortdesc lang="en">Script to run to retrieve password</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="plug" unique="0" required="0" obsoletes="port">
7f4c66
 		<getopt mixed="-n, --plug=[ip]" />
7f4c66
 		<content type="string"  />
7f4c66
 		<shortdesc lang="en">IP address or hostname of fencing device (together with --port-as-ip)</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="username" unique="0" required="1" obsoletes="login">
7f4c66
-		<getopt mixed="-l, --username=[name]" />
7f4c66
+	<parameter name="port" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="-n, --plug=[ip]" />
7f4c66
 		<content type="string"  />
7f4c66
-		<shortdesc lang="en">Login Name</shortdesc>
7f4c66
+		<shortdesc lang="en">IP address or hostname of fencing device (together with --port-as-ip)</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="redfish-uri" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="--redfish-uri=[uri]" />
7f4c66
+		<content type="string" default="/redfish/v1"  />
7f4c66
+		<shortdesc lang="en">Base or starting Redfish URI</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="redfish_uri" unique="0" required="0" obsoletes="redfish-uri">
7f4c66
 		<getopt mixed="--redfish-uri=[uri]" />
7f4c66
 		<content type="string" default="/redfish/v1"  />
7f4c66
 		<shortdesc lang="en">Base or starting Redfish URI</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="ip" unique="0" required="0" obsoletes="ipaddr">
7f4c66
-		<getopt mixed="-a, --ip=[ip]" />
7f4c66
+	<parameter name="ssl" unique="0" required="0">
7f4c66
+		<getopt mixed="-z, --ssl" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Use SSL connection with verifying certificate</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="ssl_insecure" unique="0" required="0">
7f4c66
+		<getopt mixed="--ssl-insecure" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Use SSL connection without verifying certificate</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="ssl_secure" unique="0" required="0">
7f4c66
+		<getopt mixed="--ssl-secure" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Use SSL connection with verifying certificate</shortdesc>
7f4c66
+	</parameter>
7f4c66
+	<parameter name="systems-uri" unique="0" required="0" deprecated="1">
7f4c66
+		<getopt mixed="--systems-uri=[uri]" />
7f4c66
 		<content type="string"  />
7f4c66
-		<shortdesc lang="en">IP Address or Hostname</shortdesc>
7f4c66
+		<shortdesc lang="en">Redfish Systems resource URI, i.e. /redfish/v1/Systems/System.Embedded.1</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="systems_uri" unique="0" required="0" obsoletes="systems-uri">
7f4c66
 		<getopt mixed="--systems-uri=[uri]" />
7f4c66
 		<content type="string"  />
7f4c66
 		<shortdesc lang="en">Redfish Systems resource URI, i.e. /redfish/v1/Systems/System.Embedded.1</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="password" unique="0" required="0" obsoletes="passwd">
7f4c66
-		<getopt mixed="-p, --password=[password]" />
7f4c66
+	<parameter name="username" unique="0" required="1" obsoletes="login">
7f4c66
+		<getopt mixed="-l, --username=[name]" />
7f4c66
 		<content type="string"  />
7f4c66
-		<shortdesc lang="en">Login password or passphrase</shortdesc>
7f4c66
+		<shortdesc lang="en">Login name</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="password_script" unique="0" required="0" obsoletes="passwd_script">
7f4c66
-		<getopt mixed="-S, --password-script=[script]" />
7f4c66
-		<content type="string"  />
7f4c66
-		<shortdesc lang="en">Script to retrieve password</shortdesc>
7f4c66
+	<parameter name="quiet" unique="0" required="0">
7f4c66
+		<getopt mixed="-q, --quiet" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Disable logging to stderr. Does not affect --verbose or --debug-file or logging to syslog.</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="verbose" unique="0" required="0">
7f4c66
 		<getopt mixed="-v, --verbose" />
7f4c66
@@ -133,41 +138,45 @@
7f4c66
 		<content type="boolean"  />
7f4c66
 		<shortdesc lang="en">Display help and exit</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="power_wait" unique="0" required="0">
7f4c66
-		<getopt mixed="--power-wait=[seconds]" />
7f4c66
+	<parameter name="delay" unique="0" required="0">
7f4c66
+		<getopt mixed="--delay=[seconds]" />
7f4c66
 		<content type="second" default="0"  />
7f4c66
-		<shortdesc lang="en">Wait X seconds after issuing ON/OFF</shortdesc>
7f4c66
+		<shortdesc lang="en">Wait X seconds before fencing is started</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="login_timeout" unique="0" required="0">
7f4c66
 		<getopt mixed="--login-timeout=[seconds]" />
7f4c66
 		<content type="second" default="5"  />
7f4c66
 		<shortdesc lang="en">Wait X seconds for cmd prompt after login</shortdesc>
7f4c66
 	</parameter>
7f4c66
+	<parameter name="port_as_ip" unique="0" required="0">
7f4c66
+		<getopt mixed="--port-as-ip" />
7f4c66
+		<content type="boolean"  />
7f4c66
+		<shortdesc lang="en">Make "port/plug" to be an alias to IP address</shortdesc>
7f4c66
+	</parameter>
7f4c66
 	<parameter name="power_timeout" unique="0" required="0">
7f4c66
 		<getopt mixed="--power-timeout=[seconds]" />
7f4c66
 		<content type="second" default="20"  />
7f4c66
 		<shortdesc lang="en">Test X seconds for status change after ON/OFF</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="delay" unique="0" required="0">
7f4c66
-		<getopt mixed="--delay=[seconds]" />
7f4c66
+	<parameter name="power_wait" unique="0" required="0">
7f4c66
+		<getopt mixed="--power-wait=[seconds]" />
7f4c66
 		<content type="second" default="0"  />
7f4c66
-		<shortdesc lang="en">Wait X seconds before fencing is started</shortdesc>
7f4c66
+		<shortdesc lang="en">Wait X seconds after issuing ON/OFF</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="shell_timeout" unique="0" required="0">
7f4c66
 		<getopt mixed="--shell-timeout=[seconds]" />
7f4c66
 		<content type="second" default="3"  />
7f4c66
 		<shortdesc lang="en">Wait X seconds for cmd prompt after issuing command</shortdesc>
7f4c66
 	</parameter>
7f4c66
-	<parameter name="port_as_ip" unique="0" required="0">
7f4c66
-		<getopt mixed="--port-as-ip" />
7f4c66
-		<content type="boolean"  />
7f4c66
-		<shortdesc lang="en">Make "port/plug" to be an alias to IP address</shortdesc>
7f4c66
-	</parameter>
7f4c66
 	<parameter name="retry_on" unique="0" required="0">
7f4c66
 		<getopt mixed="--retry-on=[attempts]" />
7f4c66
 		<content type="integer" default="1"  />
7f4c66
 		<shortdesc lang="en">Count of attempts to retry power on</shortdesc>
7f4c66
 	</parameter>
7f4c66
+	<parameter name="gnutlscli_path" unique="0" required="0">
7f4c66
+		<getopt mixed="--gnutlscli-path=[path]" />
7f4c66
+		<shortdesc lang="en">Path to gnutls-cli binary</shortdesc>
7f4c66
+	</parameter>
7f4c66
 </parameters>
7f4c66
 <actions>
7f4c66
 	<action name="on" automatic="0"/>
7f4c66
@@ -176,6 +185,7 @@
7f4c66
 	<action name="status" />
7f4c66
 	<action name="monitor" />
7f4c66
 	<action name="metadata" />
7f4c66
+	<action name="manpage" />
7f4c66
 	<action name="validate-all" />
7f4c66
 </actions>
7f4c66
 </resource-agent>
7f4c66
7f4c66
From 755627fadd711848ea256d72f5e75f36f83b4d31 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Mon, 3 Dec 2018 11:55:23 -0600
7f4c66
Subject: [PATCH 3/8] Added run_delay()
7f4c66
7f4c66
---
7f4c66
 agents/redfish/fence_redfish.py | 3 ++-
7f4c66
 1 file changed, 2 insertions(+), 1 deletion(-)
7f4c66
7f4c66
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
7f4c66
index df7cf8c2..0e4a4f68 100644
7f4c66
--- a/agents/redfish/fence_redfish.py
7f4c66
+++ b/agents/redfish/fence_redfish.py
7f4c66
@@ -13,7 +13,7 @@
7f4c66
 
7f4c66
 from requests.packages.urllib3.exceptions import InsecureRequestWarning
7f4c66
 from fencing import *
7f4c66
-from fencing import fail_usage
7f4c66
+from fencing import fail_usage, run_delay
7f4c66
 
7f4c66
 def get_power_status(conn, options):
7f4c66
     uri = options["--systems-uri"]
7f4c66
@@ -127,6 +127,7 @@ def main():
7f4c66
 access to control power on a server."
7f4c66
     docs["vendorurl"] = "http://www.dmtf.org"
7f4c66
     show_docs(options, docs)
7f4c66
+    run_delay(options)
7f4c66
 
7f4c66
     ##
7f4c66
     ## Operate the fencing device
7f4c66
7f4c66
From 15fef4c47f391a3f03c714d86c9670ea209dec99 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Tue, 4 Dec 2018 10:56:58 -0600
7f4c66
Subject: [PATCH 4/8] Modify power status check
7f4c66
7f4c66
- Only returns off if PowerState = Off
7f4c66
- Otherwise returns on
7f4c66
---
7f4c66
 agents/redfish/fence_redfish.py | 6 +++---
7f4c66
 1 file changed, 3 insertions(+), 3 deletions(-)
7f4c66
7f4c66
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
7f4c66
index 0e4a4f68..7998fb1c 100644
7f4c66
--- a/agents/redfish/fence_redfish.py
7f4c66
+++ b/agents/redfish/fence_redfish.py
7f4c66
@@ -21,10 +21,10 @@ def get_power_status(conn, options):
7f4c66
     if response['ret'] is False:
7f4c66
         fail_usage("Couldn't get power information")
7f4c66
     data = response['data']
7f4c66
-    if data[u'PowerState'].strip() == "On":
7f4c66
-        return "on"
7f4c66
-    else:
7f4c66
+    if data[u'PowerState'].strip() == "Off":
7f4c66
         return "off"
7f4c66
+    else:
7f4c66
+        return "on"
7f4c66
 
7f4c66
 def set_power_status(conn, options):
7f4c66
     action = {
7f4c66
7f4c66
From acf70f4672be65562841227ab0b4cacb87965f44 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Wed, 5 Dec 2018 10:39:32 -0600
7f4c66
Subject: [PATCH 5/8] Changed reboot type to ForceRestart
7f4c66
7f4c66
---
7f4c66
 agents/redfish/fence_redfish.py | 2 +-
7f4c66
 1 file changed, 1 insertion(+), 1 deletion(-)
7f4c66
7f4c66
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
7f4c66
index 7998fb1c..3fe2bfc0 100644
7f4c66
--- a/agents/redfish/fence_redfish.py
7f4c66
+++ b/agents/redfish/fence_redfish.py
7f4c66
@@ -30,7 +30,7 @@ def set_power_status(conn, options):
7f4c66
     action = {
7f4c66
         'on' : "On",
7f4c66
         'off': "ForceOff",
7f4c66
-        'reboot': "GracefulRestart"
7f4c66
+        'reboot': "ForceRestart"
7f4c66
     }[options["--action"]]
7f4c66
 
7f4c66
     payload = {'ResetType': action}
7f4c66
7f4c66
From 56e3358d45050ac669c099c56873feefa1ecda38 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Wed, 5 Dec 2018 10:54:44 -0600
7f4c66
Subject: [PATCH 6/8] Replaced default port 443 with default ssl enabled option
7f4c66
7f4c66
---
7f4c66
 agents/redfish/fence_redfish.py       | 2 +-
7f4c66
 tests/data/metadata/fence_redfish.xml | 2 +-
7f4c66
 2 files changed, 2 insertions(+), 2 deletions(-)
7f4c66
7f4c66
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
7f4c66
index 3fe2bfc0..6a2dbb76 100644
7f4c66
--- a/agents/redfish/fence_redfish.py
7f4c66
+++ b/agents/redfish/fence_redfish.py
7f4c66
@@ -117,7 +117,7 @@ def main():
7f4c66
 
7f4c66
     opt = process_input(device_opt)
7f4c66
 
7f4c66
-    all_opt["ipport"]["default"] = "443"
7f4c66
+    all_opt["ssl"]["default"] = "1"
7f4c66
     options = check_input(device_opt, opt)
7f4c66
 
7f4c66
     docs = {}
7f4c66
diff --git a/tests/data/metadata/fence_redfish.xml b/tests/data/metadata/fence_redfish.xml
7f4c66
index a39541e6..e1c18584 100644
7f4c66
--- a/tests/data/metadata/fence_redfish.xml
7f4c66
+++ b/tests/data/metadata/fence_redfish.xml
7f4c66
@@ -80,7 +80,7 @@
7f4c66
 	</parameter>
7f4c66
 	<parameter name="ssl" unique="0" required="0">
7f4c66
 		<getopt mixed="-z, --ssl" />
7f4c66
-		<content type="boolean"  />
7f4c66
+		<content type="boolean" default="1"  />
7f4c66
 		<shortdesc lang="en">Use SSL connection with verifying certificate</shortdesc>
7f4c66
 	</parameter>
7f4c66
 	<parameter name="ssl_insecure" unique="0" required="0">
7f4c66
7f4c66
From 5c25a85b22a17d6bbc3dcb47c99b76e3a99a5857 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Wed, 5 Dec 2018 13:29:42 -0600
7f4c66
Subject: [PATCH 7/8] Renamed variable to avoid reusing variable name
7f4c66
7f4c66
---
7f4c66
 agents/redfish/fence_redfish.py | 4 ++--
7f4c66
 1 file changed, 2 insertions(+), 2 deletions(-)
7f4c66
7f4c66
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
7f4c66
index 6a2dbb76..1ea25cd8 100644
7f4c66
--- a/agents/redfish/fence_redfish.py
7f4c66
+++ b/agents/redfish/fence_redfish.py
7f4c66
@@ -42,9 +42,9 @@ def set_power_status(conn, options):
7f4c66
     if response['ret'] is False:
7f4c66
         return {'ret': False}
7f4c66
     data = response['data']
7f4c66
-    uri = data["Actions"]["#ComputerSystem.Reset"]["target"]
7f4c66
+    action_uri = data["Actions"]["#ComputerSystem.Reset"]["target"]
7f4c66
 
7f4c66
-    response = send_post_request(options, uri, payload, headers)
7f4c66
+    response = send_post_request(options, action_uri, payload, headers)
7f4c66
     if response['ret'] is False:
7f4c66
         fail_usage("Error sending power command")
7f4c66
     return
7f4c66
7f4c66
From 7dce8b1e22d57fec0d34e91a99fab9d8a06f1303 Mon Sep 17 00:00:00 2001
7f4c66
From: Jose Delarosa <jose.delarosa@dell.com>
7f4c66
Date: Thu, 6 Dec 2018 10:33:06 -0600
7f4c66
Subject: [PATCH 8/8] Removed unnecessary variable assignments to simplify code
7f4c66
7f4c66
---
7f4c66
 agents/redfish/fence_redfish.py | 12 ++++--------
7f4c66
 1 file changed, 4 insertions(+), 8 deletions(-)
7f4c66
7f4c66
diff --git a/agents/redfish/fence_redfish.py b/agents/redfish/fence_redfish.py
7f4c66
index 1ea25cd8..67ef67ab 100644
7f4c66
--- a/agents/redfish/fence_redfish.py
7f4c66
+++ b/agents/redfish/fence_redfish.py
7f4c66
@@ -16,8 +16,7 @@
7f4c66
 from fencing import fail_usage, run_delay
7f4c66
 
7f4c66
 def get_power_status(conn, options):
7f4c66
-    uri = options["--systems-uri"]
7f4c66
-    response = send_get_request(options, uri)
7f4c66
+    response = send_get_request(options, options["--systems-uri"])
7f4c66
     if response['ret'] is False:
7f4c66
         fail_usage("Couldn't get power information")
7f4c66
     data = response['data']
7f4c66
@@ -37,8 +36,7 @@ def set_power_status(conn, options):
7f4c66
     headers = {'content-type': 'application/json'}
7f4c66
 
7f4c66
     # Search for 'Actions' key and extract URI from it
7f4c66
-    uri = options["--systems-uri"]
7f4c66
-    response = send_get_request(options, uri)
7f4c66
+    response = send_get_request(options, options["--systems-uri"])
7f4c66
     if response['ret'] is False:
7f4c66
         return {'ret': False}
7f4c66
     data = response['data']
7f4c66
@@ -70,8 +68,7 @@ def send_post_request(options, uri, payload, headers):
7f4c66
     return {'ret': True}
7f4c66
 
7f4c66
 def find_systems_resource(options):
7f4c66
-    uri = options["--redfish-uri"]
7f4c66
-    response = send_get_request(options, uri)
7f4c66
+    response = send_get_request(options, options["--redfish-uri"])
7f4c66
     if response['ret'] is False:
7f4c66
         return {'ret': False}
7f4c66
     data = response['data']
7f4c66
@@ -80,8 +77,7 @@ def find_systems_resource(options):
7f4c66
         # Systems resource not found"
7f4c66
         return {'ret': False}
7f4c66
     else:
7f4c66
-        uri = data["Systems"]["@odata.id"]
7f4c66
-        response = send_get_request(options, uri)
7f4c66
+        response = send_get_request(options, data["Systems"]["@odata.id"])
7f4c66
         if response['ret'] is False:
7f4c66
             return {'ret': False}
7f4c66
         data = response['data']