Blame SOURCES/bz1781357-fence_aws-improve-logging-and-metadata-usage-text.patch

91f48e
From 7ac16fb281fa8cfc51a31f672014c614c81aec82 Mon Sep 17 00:00:00 2001
91f48e
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
91f48e
Date: Fri, 31 Jan 2020 15:53:47 +0100
91f48e
Subject: [PATCH] fence_aws: improve logging and metadata/usage text
91f48e
91f48e
---
91f48e
 agents/aws/fence_aws.py           | 36 +++++++++++++++++++------------
91f48e
 tests/data/metadata/fence_aws.xml |  6 +++---
91f48e
 2 files changed, 25 insertions(+), 17 deletions(-)
91f48e
91f48e
diff --git a/agents/aws/fence_aws.py b/agents/aws/fence_aws.py
91f48e
index 647b66fc..74321e8e 100644
91f48e
--- a/agents/aws/fence_aws.py
91f48e
+++ b/agents/aws/fence_aws.py
91f48e
@@ -5,7 +5,7 @@
91f48e
 import atexit
91f48e
 sys.path.append("@FENCEAGENTSLIBDIR@")
91f48e
 from fencing import *
91f48e
-from fencing import fail, fail_usage, EC_TIMED_OUT, run_delay
91f48e
+from fencing import fail, fail_usage, run_delay, EC_STATUS
91f48e
 
91f48e
 import boto3
91f48e
 from botocore.exceptions import ClientError, EndpointConnectionError, NoRegionError
91f48e
@@ -19,6 +19,8 @@ def get_nodes_list(conn, options):
91f48e
 		fail_usage("Failed: Incorrect Access Key or Secret Key.")
91f48e
 	except EndpointConnectionError:
91f48e
 		fail_usage("Failed: Incorrect Region.")
91f48e
+	except Exception as e:
91f48e
+		logging.error("Failed to get node list: %s", e)
91f48e
 
91f48e
 	return result
91f48e
 
91f48e
@@ -38,20 +40,26 @@ def get_power_status(conn, options):
91f48e
 	except EndpointConnectionError:
91f48e
 		fail_usage("Failed: Incorrect Region.")
91f48e
 	except IndexError:
91f48e
-		return "fail"
91f48e
+		fail(EC_STATUS)
91f48e
+	except Exception as e:
91f48e
+		logging.error("Failed to get power status: %s", e)
91f48e
+		fail(EC_STATUS)
91f48e
 
91f48e
 def set_power_status(conn, options):
91f48e
-	if (options["--action"]=="off"):
91f48e
-		conn.instances.filter(InstanceIds=[options["--plug"]]).stop(Force=True)
91f48e
-	elif (options["--action"]=="on"):
91f48e
-		conn.instances.filter(InstanceIds=[options["--plug"]]).start()
91f48e
-
91f48e
+	try:
91f48e
+		if (options["--action"]=="off"):
91f48e
+			conn.instances.filter(InstanceIds=[options["--plug"]]).stop(Force=True)
91f48e
+		elif (options["--action"]=="on"):
91f48e
+			conn.instances.filter(InstanceIds=[options["--plug"]]).start()
91f48e
+	except Exception as e:
91f48e
+		logging.error("Failed to power %s %s: %s", \
91f48e
+				options["--action"], options["--plug"], e)
91f48e
 
91f48e
 def define_new_opts():
91f48e
 	all_opt["region"] = {
91f48e
 		"getopt" : "r:",
91f48e
 		"longopt" : "region",
91f48e
-		"help" : "-r, --region=[name]            Region, e.g. us-east-1",
91f48e
+		"help" : "-r, --region=[region]           Region, e.g. us-east-1",
91f48e
 		"shortdesc" : "Region.",
91f48e
 		"required" : "0",
91f48e
 		"order" : 2
91f48e
@@ -59,7 +67,7 @@ def define_new_opts():
91f48e
 	all_opt["access_key"] = {
91f48e
 		"getopt" : "a:",
91f48e
 		"longopt" : "access-key",
91f48e
-		"help" : "-a, --access-key=[name]         Access Key",
91f48e
+		"help" : "-a, --access-key=[key]         Access Key",
91f48e
 		"shortdesc" : "Access Key.",
91f48e
 		"required" : "0",
91f48e
 		"order" : 3
91f48e
@@ -67,7 +75,7 @@ def define_new_opts():
91f48e
 	all_opt["secret_key"] = {
91f48e
 		"getopt" : "s:",
91f48e
 		"longopt" : "secret-key",
91f48e
-		"help" : "-s, --secret-key=[name]         Secret Key",
91f48e
+		"help" : "-s, --secret-key=[key]         Secret Key",
91f48e
 		"shortdesc" : "Secret Key.",
91f48e
 		"required" : "0",
91f48e
 		"order" : 4
91f48e
@@ -107,16 +115,16 @@ def main():
91f48e
 			conn = boto3.resource('ec2', region_name=region,
91f48e
 					      aws_access_key_id=access_key,
91f48e
 					      aws_secret_access_key=secret_key)
91f48e
-		except:
91f48e
-			fail_usage("Failed: Unable to connect to AWS. Check your configuration.")
91f48e
+		except Exception as e:
91f48e
+			fail_usage("Failed: Unable to connect to AWS: " + str(e))
91f48e
 	else:
91f48e
 		# If setup with "aws configure" or manually in
91f48e
 		# ~/.aws/credentials
91f48e
 		try:
91f48e
 			conn = boto3.resource('ec2')
91f48e
-		except:
91f48e
+		except Exception as e:
91f48e
 			# If any of region/access/secret are missing
91f48e
-			fail_usage("Failed: Unable to connect to AWS. Check your configuration.")
91f48e
+			fail_usage("Failed: Unable to connect to AWS: " + str(e))
91f48e
 
91f48e
 	# Operate the fencing device
91f48e
 	result = fence_action(conn, options, set_power_status, get_power_status, get_nodes_list)
91f48e
diff --git a/tests/data/metadata/fence_aws.xml b/tests/data/metadata/fence_aws.xml
91f48e
index 4dea4418..5e5d5d99 100644
91f48e
--- a/tests/data/metadata/fence_aws.xml
91f48e
+++ b/tests/data/metadata/fence_aws.xml
91f48e
@@ -22,17 +22,17 @@ For instructions see: https://boto3.readthedocs.io/en/latest/guide/quickstart.ht
91f48e
 		<shortdesc lang="en">Physical plug number on device, UUID or identification of machine</shortdesc>
91f48e
 	</parameter>
91f48e
 	<parameter name="region" unique="0" required="0">
91f48e
-		<getopt mixed="-r, --region=[name]" />
91f48e
+		<getopt mixed="-r, --region=[region]" />
91f48e
 		<content type="string"  />
91f48e
 		<shortdesc lang="en">Region.</shortdesc>
91f48e
 	</parameter>
91f48e
 	<parameter name="access_key" unique="0" required="0">
91f48e
-		<getopt mixed="-a, --access-key=[name]" />
91f48e
+		<getopt mixed="-a, --access-key=[key]" />
91f48e
 		<content type="string"  />
91f48e
 		<shortdesc lang="en">Access Key.</shortdesc>
91f48e
 	</parameter>
91f48e
 	<parameter name="secret_key" unique="0" required="0">
91f48e
-		<getopt mixed="-s, --secret-key=[name]" />
91f48e
+		<getopt mixed="-s, --secret-key=[key]" />
91f48e
 		<content type="string"  />
91f48e
 		<shortdesc lang="en">Secret Key.</shortdesc>
91f48e
 	</parameter>