Blame SOURCES/bz1535415-fence_compute-fence_evacuate-add-support-for-keystone-v3-authentication.patch

e4ffb1
diff -uNr a/fence/agents/compute/fence_compute.py b/fence/agents/compute/fence_compute.py
e4ffb1
--- a/fence/agents/compute/fence_compute.py	2018-01-10 13:46:17.965287100 +0100
e4ffb1
+++ b/fence/agents/compute/fence_compute.py	2018-01-11 10:01:12.288043619 +0100
e4ffb1
@@ -11,12 +11,6 @@
e4ffb1
 from fencing import *
e4ffb1
 from fencing import fail_usage, is_executable, run_command, run_delay
e4ffb1
 
e4ffb1
-#BEGIN_VERSION_GENERATION
e4ffb1
-RELEASE_VERSION="4.0.11"
e4ffb1
-BUILD_DATE="(built Wed Nov 12 06:33:38 EST 2014)"
e4ffb1
-REDHAT_COPYRIGHT="Copyright (C) Red Hat, Inc. 2004-2010 All rights reserved."
e4ffb1
-#END_VERSION_GENERATION
e4ffb1
-
e4ffb1
 override_status = ""
e4ffb1
 
e4ffb1
 EVACUABLE_TAG = "evacuable"
e4ffb1
@@ -264,13 +258,37 @@
e4ffb1
 	except ImportError:
e4ffb1
 		fail_usage("Nova not found or not accessible")
e4ffb1
 
e4ffb1
-	versions = [ "2.11", "2" ]
e4ffb1
-	for version in versions:
e4ffb1
-		clientargs = inspect.getargspec(client.Client).varargs
e4ffb1
+	from keystoneauth1 import loading
e4ffb1
+	from keystoneauth1 import session
e4ffb1
+	from keystoneclient import discover
e4ffb1
+
e4ffb1
+	# Prefer the oldest and strip the leading 'v'
e4ffb1
+	keystone_versions = discover.available_versions(options["--auth-url"])
e4ffb1
+	keystone_version = keystone_versions[0]['id'][1:]
e4ffb1
+	kwargs = dict(
e4ffb1
+		auth_url=options["--auth-url"],
e4ffb1
+		username=options["--username"],
e4ffb1
+		password=options["--password"]
e4ffb1
+		)
e4ffb1
+
e4ffb1
+	if discover.version_match("2", keystone_version):
e4ffb1
+		kwargs["tenant_name"] = options["--tenant-name"]
e4ffb1
+
e4ffb1
+	elif discover.version_match("3", keystone_version):
e4ffb1
+		kwargs["project_name"] = options["--tenant-name"]
e4ffb1
+		kwargs["user_domain_name"] = options["--user-domain"]
e4ffb1
+		kwargs["project_domain_name"] = options["--project-domain"]
e4ffb1
+
e4ffb1
+	loader = loading.get_plugin_loader('password')
e4ffb1
+	keystone_auth = loader.load_from_options(**kwargs)
e4ffb1
+	keystone_session = session.Session(auth=keystone_auth, verify=(not options["--insecure"]))
e4ffb1
 
e4ffb1
+	nova_versions = [ "2.11", "2" ]
e4ffb1
+	for version in nova_versions:
e4ffb1
+		clientargs = inspect.getargspec(client.Client).varargs
e4ffb1
 		# Some versions of Openstack prior to Ocata only
e4ffb1
 		# supported positional arguments for username,
e4ffb1
-		# password and tenant.
e4ffb1
+		# password, and tenant.
e4ffb1
 		#
e4ffb1
 		# Versions since Ocata only support named arguments.
e4ffb1
 		#
e4ffb1
@@ -285,25 +303,22 @@
e4ffb1
 			#	 varargs=None,
e4ffb1
 			#	 keywords='kwargs', defaults=(None, None, None, None))
e4ffb1
 			nova = client.Client(version,
e4ffb1
-					     options["--username"],
e4ffb1
-					     options["--password"],
e4ffb1
-					     options["--tenant-name"],
e4ffb1
-					     options["--auth-url"],
e4ffb1
+					     None, # User
e4ffb1
+					     None, # Password
e4ffb1
+					     None, # Tenant
e4ffb1
+					     None, # Auth URL
e4ffb1
 					     insecure=options["--insecure"],
e4ffb1
 					     region_name=options["--region-name"],
e4ffb1
 					     endpoint_type=options["--endpoint-type"],
e4ffb1
+					     session=keystone_session, auth=keystone_auth,
e4ffb1
 					     http_log_debug=options.has_key("--verbose"))
e4ffb1
 		else:
e4ffb1
 			# OSP >= 11
e4ffb1
 			# ArgSpec(args=['version'], varargs='args', keywords='kwargs', defaults=None)
e4ffb1
 			nova = client.Client(version,
e4ffb1
-					     username=options["--username"],
e4ffb1
-					     password=options["--password"],
e4ffb1
-					     tenant_name=options["--tenant-name"],
e4ffb1
-					     auth_url=options["--auth-url"],
e4ffb1
-					     insecure=options["--insecure"],
e4ffb1
 					     region_name=options["--region-name"],
e4ffb1
 					     endpoint_type=options["--endpoint-type"],
e4ffb1
+					     session=keystone_session, auth=keystone_auth,
e4ffb1
 					     http_log_debug=options.has_key("--verbose"))
e4ffb1
 
e4ffb1
 		try:
e4ffb1
@@ -316,7 +331,7 @@
e4ffb1
 		except Exception as e:
e4ffb1
 			logging.warning("Nova connection failed. %s: %s" % (e.__class__.__name__, e))
e4ffb1
 
e4ffb1
-	logging.warning("Couldn't obtain a supported connection to nova, tried: %s\n" % repr(versions))
e4ffb1
+	logging.warning("Couldn't obtain a supported connection to nova, tried: %s\n" % repr(nova_versions))
e4ffb1
 	return None
e4ffb1
 
e4ffb1
 def define_new_opts():
e4ffb1
@@ -332,12 +347,30 @@
e4ffb1
 	all_opt["tenant_name"] = {
e4ffb1
 		"getopt" : "t:",
e4ffb1
 		"longopt" : "tenant-name",
e4ffb1
-		"help" : "-t, --tenant-name=[tenant]     Keystone Admin Tenant",
e4ffb1
+		"help" : "-t, --tenant-name=[name]       Keystone v2 Tenant or v3 Project Name",
e4ffb1
 		"required" : "0",
e4ffb1
-		"shortdesc" : "Keystone Admin Tenant",
e4ffb1
+		"shortdesc" : "Keystone Admin Tenant or v3 Project",
e4ffb1
 		"default" : "",
e4ffb1
 		"order": 1,
e4ffb1
 	}
e4ffb1
+	all_opt["user-domain"] = {
e4ffb1
+		"getopt" : "u:",
e4ffb1
+		"longopt" : "user-domain",
e4ffb1
+		"help" : "-u, --user-domain=[name]       Keystone v3 User Domain",
e4ffb1
+		"required" : "0",
e4ffb1
+		"shortdesc" : "Keystone v3 User Domain",
e4ffb1
+		"default" : "Default",
e4ffb1
+		"order": 2,
e4ffb1
+	}
e4ffb1
+	all_opt["project-domain"] = {
e4ffb1
+		"getopt" : "P:",
e4ffb1
+		"longopt" : "project-domain",
e4ffb1
+		"help" : "-d, --project-domain=[name]    Keystone v3 Project Domain",
e4ffb1
+		"required" : "0",
e4ffb1
+		"shortdesc" : "Keystone v3 Project Domain",
e4ffb1
+		"default" : "Default",
e4ffb1
+		"order": 2,
e4ffb1
+	}
e4ffb1
 	all_opt["auth_url"] = {
e4ffb1
 		"getopt" : "k:",
e4ffb1
 		"longopt" : "auth-url",
e4ffb1
@@ -365,7 +398,7 @@
e4ffb1
 		"default" : "False",
e4ffb1
 		"order": 2,
e4ffb1
 	}
e4ffb1
-	all_opt["domain"] = {
e4ffb1
+	all_opt["compute-domain"] = {
e4ffb1
 		"getopt" : "d:",
e4ffb1
 		"longopt" : "domain",
e4ffb1
 		"help" : "-d, --domain=[string]          DNS domain in which hosts live, useful when the cluster uses short names and nova uses FQDN",
e4ffb1
@@ -418,8 +451,8 @@
e4ffb1
 	atexit.register(atexit_handler)
e4ffb1
 
e4ffb1
 	device_opt = ["login", "passwd", "tenant_name", "auth_url", "fabric_fencing",
e4ffb1
-		"no_login", "no_password", "port", "domain", "no_shared_storage", "endpoint_type",
e4ffb1
-		"record_only", "instance_filtering", "insecure", "region_name"]
e4ffb1
+		      "no_login", "no_password", "port", "compute-domain", "project-domain", "user-domain",
e4ffb1
+		      "no_shared_storage", "endpoint_type", "record_only", "instance_filtering", "insecure", "region_name"]
e4ffb1
 	define_new_opts()
e4ffb1
 	all_opt["shell_timeout"]["default"] = "180"
e4ffb1
 
e4ffb1
diff -uNr a/fence/agents/compute/fence_evacuate.py b/fence/agents/compute/fence_evacuate.py
e4ffb1
--- a/fence/agents/compute/fence_evacuate.py	2018-01-10 13:46:17.966287090 +0100
e4ffb1
+++ b/fence/agents/compute/fence_evacuate.py	2018-01-10 13:48:19.375158060 +0100
e4ffb1
@@ -191,13 +191,38 @@
e4ffb1
 	except ImportError:
e4ffb1
 		fail_usage("Nova not found or not accessible")
e4ffb1
 
e4ffb1
+	from keystoneauth1 import loading
e4ffb1
+	from keystoneauth1 import session
e4ffb1
+	from keystoneclient import discover
e4ffb1
+
e4ffb1
+	# Prefer the oldest and strip the leading 'v'
e4ffb1
+	keystone_versions = discover.available_versions(options["--auth-url"])
e4ffb1
+	keystone_version = keystone_versions[0]['id'][1:]
e4ffb1
+	kwargs = dict(
e4ffb1
+		auth_url=options["--auth-url"],
e4ffb1
+		username=options["--username"],
e4ffb1
+		password=options["--password"]
e4ffb1
+		)
e4ffb1
+
e4ffb1
+	if discover.version_match("2", keystone_version):
e4ffb1
+		kwargs["tenant_name"] = options["--tenant-name"]
e4ffb1
+
e4ffb1
+	elif discover.version_match("3", keystone_version):
e4ffb1
+		kwargs["project_name"] = options["--tenant-name"]
e4ffb1
+		kwargs["user_domain_name"] = options["--user-domain"]
e4ffb1
+		kwargs["project_domain_name"] = options["--project-domain"]
e4ffb1
+
e4ffb1
+	loader = loading.get_plugin_loader('password')
e4ffb1
+	keystone_auth = loader.load_from_options(**kwargs)
e4ffb1
+	keystone_session = session.Session(auth=keystone_auth, verify=(not options["--insecure"]))
e4ffb1
+
e4ffb1
 	versions = [ "2.11", "2" ]
e4ffb1
 	for version in versions:
e4ffb1
 		clientargs = inspect.getargspec(client.Client).varargs
e4ffb1
 
e4ffb1
 		# Some versions of Openstack prior to Ocata only
e4ffb1
 		# supported positional arguments for username,
e4ffb1
-		# password and tenant.
e4ffb1
+		# password, and tenant.
e4ffb1
 		#
e4ffb1
 		# Versions since Ocata only support named arguments.
e4ffb1
 		#
e4ffb1
@@ -212,25 +237,22 @@
e4ffb1
 			#	 varargs=None,
e4ffb1
 			#	 keywords='kwargs', defaults=(None, None, None, None))
e4ffb1
 			nova = client.Client(version,
e4ffb1
-					     options["--username"],
e4ffb1
-					     options["--password"],
e4ffb1
-					     options["--tenant-name"],
e4ffb1
-					     options["--auth-url"],
e4ffb1
+					     None, # User
e4ffb1
+					     None, # Password
e4ffb1
+					     None, # Tenant
e4ffb1
+					     None, # Auth URL
e4ffb1
 					     insecure=options["--insecure"],
e4ffb1
 					     region_name=options["--region-name"],
e4ffb1
 					     endpoint_type=options["--endpoint-type"],
e4ffb1
+					     session=keystone_session, auth=keystone_auth,
e4ffb1
 					     http_log_debug=options.has_key("--verbose"))
e4ffb1
 		else:
e4ffb1
 			# OSP >= 11
e4ffb1
 			# ArgSpec(args=['version'], varargs='args', keywords='kwargs', defaults=None)
e4ffb1
 			nova = client.Client(version,
e4ffb1
-					     username=options["--username"],
e4ffb1
-					     password=options["--password"],
e4ffb1
-					     tenant_name=options["--tenant-name"],
e4ffb1
-					     auth_url=options["--auth-url"],
e4ffb1
-					     insecure=options["--insecure"],
e4ffb1
 					     region_name=options["--region-name"],
e4ffb1
 					     endpoint_type=options["--endpoint-type"],
e4ffb1
+					     session=keystone_session, auth=keystone_auth,
e4ffb1
 					     http_log_debug=options.has_key("--verbose"))
e4ffb1
 
e4ffb1
 		try:
e4ffb1
@@ -259,12 +281,30 @@
e4ffb1
 	all_opt["tenant_name"] = {
e4ffb1
 		"getopt" : "t:",
e4ffb1
 		"longopt" : "tenant-name",
e4ffb1
-		"help" : "-t, --tenant-name=[tenant]     Keystone Admin Tenant",
e4ffb1
+		"help" : "-t, --tenant-name=[name]       Keystone v2 Tenant or v3 Project Name",
e4ffb1
 		"required" : "0",
e4ffb1
-		"shortdesc" : "Keystone Admin Tenant",
e4ffb1
+		"shortdesc" : "Keystone Admin Tenant or v3 Project",
e4ffb1
 		"default" : "",
e4ffb1
 		"order": 1,
e4ffb1
 	}
e4ffb1
+	all_opt["user-domain"] = {
e4ffb1
+		"getopt" : "u:",
e4ffb1
+		"longopt" : "user-domain",
e4ffb1
+		"help" : "-u, --user-domain=[name]       Keystone v3 User Domain",
e4ffb1
+		"required" : "0",
e4ffb1
+		"shortdesc" : "Keystone v3 User Domain",
e4ffb1
+		"default" : "Default",
e4ffb1
+		"order": 2,
e4ffb1
+	}
e4ffb1
+	all_opt["project-domain"] = {
e4ffb1
+		"getopt" : "P:",
e4ffb1
+		"longopt" : "project-domain",
e4ffb1
+		"help" : "-d, --project-domain=[name]    Keystone v3 Project Domain",
e4ffb1
+		"required" : "0",
e4ffb1
+		"shortdesc" : "Keystone v3 Project Domain",
e4ffb1
+		"default" : "Default",
e4ffb1
+		"order": 2,
e4ffb1
+	}
e4ffb1
 	all_opt["auth_url"] = {
e4ffb1
 		"getopt" : "k:",
e4ffb1
 		"longopt" : "auth-url",
e4ffb1
@@ -292,7 +332,7 @@
e4ffb1
 		"default" : "False",
e4ffb1
 		"order": 2,
e4ffb1
 	}
e4ffb1
-	all_opt["domain"] = {
e4ffb1
+	all_opt["compute-domain"] = {
e4ffb1
 		"getopt" : "d:",
e4ffb1
 		"longopt" : "domain",
e4ffb1
 		"help" : "-d, --domain=[string]                  DNS domain in which hosts live, useful when the cluster uses short names and nova uses FQDN",
e4ffb1
@@ -323,8 +363,9 @@
e4ffb1
 	atexit.register(atexit_handler)
e4ffb1
 
e4ffb1
 	device_opt = ["login", "passwd", "tenant_name", "auth_url",
e4ffb1
-		"no_login", "no_password", "port", "domain", "no_shared_storage", "endpoint_type",
e4ffb1
-		"instance_filtering", "insecure", "region_name"]
e4ffb1
+		      "no_login", "no_password", "port", "compute-domain", "project-domain",
e4ffb1
+		      "user-domain", "no_shared_storage", "endpoint_type",
e4ffb1
+		      "instance_filtering", "insecure", "region_name"]
e4ffb1
 	define_new_opts()
e4ffb1
 	all_opt["shell_timeout"]["default"] = "180"
e4ffb1