Blame SOURCES/bz1763674-fence_rhevm-add-cookie-support.patch

6147c0
From b885e0f65af626154096a49554e9765e18bfbbd9 Mon Sep 17 00:00:00 2001
6147c0
From: Frank Toth <ftoth1@bloomberg.net>
6147c0
Date: Wed, 16 Oct 2019 13:58:50 +0800
6147c0
Subject: [PATCH 1/3] Added cookie file management to properly reuse session
6147c0
 and do not create new one every time.
6147c0
6147c0
---
6147c0
 agents/rhevm/fence_rhevm.py | 15 ++++++++++++++-
6147c0
 1 file changed, 14 insertions(+), 1 deletion(-)
6147c0
6147c0
diff --git a/agents/rhevm/fence_rhevm.py b/agents/rhevm/fence_rhevm.py
6147c0
index 9e4650cd..defa35e6 100644
6147c0
--- a/agents/rhevm/fence_rhevm.py
6147c0
+++ b/agents/rhevm/fence_rhevm.py
6147c0
@@ -117,7 +117,12 @@ def send_command(opt, command, method="GET"):
6147c0
 		conn.setopt(pycurl.HTTPAUTH, pycurl.HTTPAUTH_BASIC)
6147c0
 		conn.setopt(pycurl.USERPWD, opt["--username"] + ":" + opt["--password"])
6147c0
 		if "--use-cookies" in opt:
6147c0
-			conn.setopt(pycurl.COOKIEFILE, "")
6147c0
+			if "--cookie-file" in opt:
6147c0
+				cookie_file = opt["--cookie-file"]
6147c0
+			else:
6147c0
+				cookie_file = "/tmp/fence_rhevm_" + opt["--ip"] + "_" + opt["--username"] + "_cookie.dat"
6147c0
+			conn.setopt(pycurl.COOKIEFILE, cookie_file)
6147c0
+			conn.setopt(pycurl.COOKIEJAR, cookie_file)
6147c0
 
6147c0
 	conn.setopt(pycurl.TIMEOUT, int(opt["--shell-timeout"]))
6147c0
 	if "--ssl" in opt or "--ssl-secure" in opt:
6147c0
@@ -166,6 +171,14 @@ def define_new_opts():
6147c0
 		"required" : "0",
6147c0
 		"shortdesc" : "Reuse cookies for authentication",
6147c0
 		"order" : 1}
6147c0
+	all_opt["cookie_file"] = {
6147c0
+		"getopt" : ":",
6147c0
+		"longopt" : "cookie-file",
6147c0
+		"help" : "--cookie-file                  Path to cookie file for authentication\n"
6147c0
+                        "\t\t\t\t  (Default: /tmp/fence_rhevm_ip_username_cookie.dat)",
6147c0
+		"required" : "0",
6147c0
+		"shortdesc" : "Path to cookie file for authentication",
6147c0
+		"order" : 2}
6147c0
 	all_opt["api_version"] = {
6147c0
 		"getopt" : ":",
6147c0
 		"longopt" : "api-version",
6147c0
6147c0
From 874344acbfee5f774b320e384a46e1ce953a34ce Mon Sep 17 00:00:00 2001
6147c0
From: Frank Toth <ftoth1@bloomberg.net>
6147c0
Date: Wed, 16 Oct 2019 23:41:50 +0800
6147c0
Subject: [PATCH 2/3] Added cookie_file to device_opt array. Use
6147c0
 tempfile.gettempdir() to get the TMP dir instead of hardcoded /tmp
6147c0
6147c0
---
6147c0
 agents/rhevm/fence_rhevm.py | 4 +++-
6147c0
 1 file changed, 3 insertions(+), 1 deletion(-)
6147c0
6147c0
diff --git a/agents/rhevm/fence_rhevm.py b/agents/rhevm/fence_rhevm.py
6147c0
index defa35e6..25aecbe5 100644
6147c0
--- a/agents/rhevm/fence_rhevm.py
6147c0
+++ b/agents/rhevm/fence_rhevm.py
6147c0
@@ -4,6 +4,7 @@
6147c0
 import pycurl, io
6147c0
 import logging
6147c0
 import atexit
6147c0
+import tempfile
6147c0
 sys.path.append("@FENCEAGENTSLIBDIR@")
6147c0
 from fencing import *
6147c0
 from fencing import fail, EC_FETCH_VM_UUID, run_delay
6147c0
@@ -120,7 +121,7 @@ def send_command(opt, command, method="GET"):
6147c0
 			if "--cookie-file" in opt:
6147c0
 				cookie_file = opt["--cookie-file"]
6147c0
 			else:
6147c0
-				cookie_file = "/tmp/fence_rhevm_" + opt["--ip"] + "_" + opt["--username"] + "_cookie.dat"
6147c0
+				cookie_file = tempfile.gettempdir() + "/fence_rhevm_" + opt["--ip"] + "_" + opt["--username"] + "_cookie.dat"
6147c0
 			conn.setopt(pycurl.COOKIEFILE, cookie_file)
6147c0
 			conn.setopt(pycurl.COOKIEJAR, cookie_file)
6147c0
 
6147c0
@@ -215,6 +216,7 @@ def main():
6147c0
 		"web",
6147c0
 		"port",
6147c0
 		"use_cookies",
6147c0
+		"cookie_file",
6147c0
 		"api_version",
6147c0
 		"api_path",
6147c0
 		"disable_http_filter",
6147c0
6147c0
From 196513cfc0edfd28f483a00b4adfa230b666a47d Mon Sep 17 00:00:00 2001
6147c0
From: Frank Toth <ftoth1@bloomberg.net>
6147c0
Date: Fri, 18 Oct 2019 05:16:18 +0200
6147c0
Subject: [PATCH 3/3] After 'make xml-upload'
6147c0
6147c0
---
6147c0
 tests/data/metadata/fence_rhevm.xml | 5 +++++
6147c0
 1 file changed, 5 insertions(+)
6147c0
6147c0
diff --git a/tests/data/metadata/fence_rhevm.xml b/tests/data/metadata/fence_rhevm.xml
6147c0
index c56cf64b..2b6b02b2 100644
6147c0
--- a/tests/data/metadata/fence_rhevm.xml
6147c0
+++ b/tests/data/metadata/fence_rhevm.xml
6147c0
@@ -103,6 +103,11 @@
6147c0
 		<content type="string" default="auto"  />
6147c0
 		<shortdesc lang="en">Version of RHEV API (default: auto)</shortdesc>
6147c0
 	</parameter>
6147c0
+	<parameter name="cookie_file" unique="0" required="0">
6147c0
+		<getopt mixed="--cookie-file" />
6147c0
+		<content type="string"  />
6147c0
+		<shortdesc lang="en">Path to cookie file for authentication</shortdesc>
6147c0
+	</parameter>
6147c0
 	<parameter name="api_path" unique="0" required="0">
6147c0
 		<getopt mixed="--api-path=[path]" />
6147c0
 		<shortdesc lang="en">The path part of the API URL</shortdesc>