Blame SOURCES/bz1843999-aliyun-vpc-move-ip-log-output-when-failing.patch

02ddf4
--- a/heartbeat/aliyun-vpc-move-ip	2020-06-09 13:41:35.308379032 +0200
02ddf4
+++ b/heartbeat/aliyun-vpc-move-ip	2020-06-05 10:48:45.555132686 +0200
02ddf4
@@ -9,12 +9,46 @@
02ddf4
 # Initialization:
02ddf4
 : ${OCF_FUNCTIONS_DIR=${OCF_ROOT}/lib/heartbeat}
02ddf4
 . ${OCF_FUNCTIONS_DIR}/ocf-shellfuncs
02ddf4
+
02ddf4
+# Parameter defaults
02ddf4
+
02ddf4
+OCF_RESKEY_address_default=""
02ddf4
+OCF_RESKEY_routing_table_default=""
02ddf4
+OCF_RESKEY_interface_default="eth0"
02ddf4
+OCF_RESKEY_profile_default="default"
02ddf4
+OCF_RESKEY_endpoint_default="vpc.aliyuncs.com"
02ddf4
+OCF_RESKEY_aliyuncli_default="detect"
02ddf4
+
02ddf4
+
02ddf4
+: ${OCF_RESKEY_address=${OCF_RESKEY_address_default}}
02ddf4
+: ${OCF_RESKEY_routing_table=${OCF_RESKEY_routing_table_default}}
02ddf4
+: ${OCF_RESKEY_interface=${OCF_RESKEY_interface_default}}
02ddf4
+: ${OCF_RESKEY_profile=${OCF_RESKEY_profile_default}}
02ddf4
+: ${OCF_RESKEY_endpoint=${OCF_RESKEY_endpoint_default}}
02ddf4
+: ${OCF_RESKEY_aliyuncli=${OCF_RESKEY_aliyuncli_default}}
02ddf4
+
02ddf4
 #######################################################################
02ddf4
 
02ddf4
-# aliyuncli doesnt work without HOME parameter
02ddf4
+# aliyun cli doesnt work without HOME parameter
02ddf4
 export HOME="/root"
02ddf4
 
02ddf4
 USAGE="usage: $0 {start|stop|status|meta-data}";
02ddf4
+
02ddf4
+if [ "${OCF_RESKEY_aliyuncli}" = "detect" ]; then
02ddf4
+	OCF_RESKEY_aliyuncli="$(which aliyuncli 2> /dev/null || which aliyun 2> /dev/null)"
02ddf4
+fi
02ddf4
+
02ddf4
+if [[ "${OCF_RESKEY_aliyuncli##*/}" == 'aliyuncli' ]]; then
02ddf4
+	OUTPUT="text"
02ddf4
+	EXECUTING='{ print $3 }'
02ddf4
+	IFS_=" "
02ddf4
+	ENDPOINT=""
02ddf4
+elif [[ "${OCF_RESKEY_aliyuncli##*/}" == 'aliyun' ]]; then
02ddf4
+	OUTPUT="table cols=InstanceId,DestinationCidrBlock rows=RouteTables.RouteTable[].RouteEntrys.RouteEntry[]"
02ddf4
+	EXECUTING='{ gsub (" ", "", $0); print $1 }'
02ddf4
+	IFS_="|"
02ddf4
+	ENDPOINT="--endpoint $OCF_RESKEY_endpoint"
02ddf4
+fi
02ddf4
 ###############################################################################
02ddf4
 
02ddf4
 
02ddf4
@@ -24,27 +58,61 @@
02ddf4
 #
02ddf4
 ###############################################################################
02ddf4
 
02ddf4
+request_create_route_entry() {
02ddf4
+	cmd="${OCF_RESKEY_aliyuncli} vpc CreateRouteEntry --RouteTableId $OCF_RESKEY_routing_table --DestinationCidrBlock ${OCF_RESKEY_address}/32 --NextHopId $ECS_INSTANCE_ID --NextHopType Instance ${ENDPOINT}"
02ddf4
+	ocf_log debug "executing command: $cmd"
02ddf4
+	res=$($cmd  2>&1)
02ddf4
+	rc=$?
02ddf4
+	if [[ $rc -eq 0 ]]
02ddf4
+	then
02ddf4
+		ocf_log debug "result: $res; rc: $rc"
02ddf4
+	else
02ddf4
+		ocf_log err "result: $res; cmd: $cmd; rc: $rc"
02ddf4
+	fi
02ddf4
+	return $rc
02ddf4
+}
02ddf4
+
02ddf4
+request_delete_route_entry() {
02ddf4
+	cmd="${OCF_RESKEY_aliyuncli} vpc DeleteRouteEntry --RouteTableId $OCF_RESKEY_routing_table --DestinationCidrBlock ${OCF_RESKEY_address}/32 --NextHopId $ROUTE_TO_INSTANCE ${ENDPOINT}"
02ddf4
+	ocf_log debug "executing command: $cmd"
02ddf4
+	res=$($cmd)
02ddf4
+	rc=$?
02ddf4
+	if [[ $rc -eq 0 ]]
02ddf4
+	then
02ddf4
+		ocf_log debug "result: $res; rc: $rc"
02ddf4
+	else
02ddf4
+		ocf_log err "result: $res; cmd: $cmd; rc: $rc"
02ddf4
+	fi
02ddf4
+	return $rc
02ddf4
+}
02ddf4
 
02ddf4
+request_describe_route_tables() {
02ddf4
+	cmd="${OCF_RESKEY_aliyuncli} vpc DescribeRouteTables --RouteTableId $OCF_RESKEY_routing_table --output ${OUTPUT} ${ENDPOINT}"
02ddf4
+	ocf_log debug "executing command: $cmd"
02ddf4
+	res=$($cmd)
02ddf4
+	rc=$?
02ddf4
+	if [[ $rc -eq 0 ]]
02ddf4
+	then
02ddf4
+		ROUTE_TO_INSTANCE=$(echo "$res" |grep "\s${OCF_RESKEY_address}/" | awk -F "${IFS_}" "${EXECUTING}")
02ddf4
+		ocf_log debug "ROUTE_TO_INSTANCE: $ROUTE_TO_INSTANCE"
02ddf4
+	else
02ddf4
+		ocf_log err "result: $res; cmd: $cmd; rc: $rc"
02ddf4
+	fi
02ddf4
+}
02ddf4
 
02ddf4
 ip_get_and_configure() {
02ddf4
 	ocf_log debug "function: ip_get_and_configure"
02ddf4
 
02ddf4
-	ROUTE_TO_INSTANCE="$($cmd |grep $OCF_RESKEY_address | awk '{ print $3 }')"
02ddf4
-
02ddf4
+	request_describe_route_tables
02ddf4
 	if [ "$ECS_INSTANCE_ID" != "$ROUTE_TO_INSTANCE" ]; then
02ddf4
 		if [ -n "$ROUTE_TO_INSTANCE" ]; then
02ddf4
 			ip_drop
02ddf4
 		fi
02ddf4
-
02ddf4
-		cmd="aliyuncli vpc CreateRouteEntry --RouteTableId $OCF_RESKEY_routing_table --DestinationCidrBlock ${OCF_RESKEY_address}/32 --NextHopId $ECS_INSTANCE_ID --NextHopType Instance --output text"
02ddf4
-		ocf_log debug "executing command: $cmd"
02ddf4
-		$cmd
02ddf4
+		request_create_route_entry
02ddf4
 		rc=$?
02ddf4
 		while [ $rc -ne 0 ]; do
02ddf4
 			sleep 1
02ddf4
-			cmd="aliyuncli vpc CreateRouteEntry --RouteTableId $OCF_RESKEY_routing_table --DestinationCidrBlock ${OCF_RESKEY_address}/32 --NextHopId $ECS_INSTANCE_ID --NextHopType Instance --output text"
02ddf4
-			ocf_log debug "executing command: $cmd"
02ddf4
-			$cmd
02ddf4
+			request_create_route_entry
02ddf4
 			rc=$?
02ddf4
 		done
02ddf4
 		wait_for_started
02ddf4
@@ -68,17 +136,15 @@
02ddf4
 	ocf_log debug "function: ip_drop"
02ddf4
 	cmd="ip addr delete ${OCF_RESKEY_address}/32 dev $OCF_RESKEY_interface"
02ddf4
 	ocf_log debug "executing command: $cmd"
02ddf4
-	$cmd
02ddf4
+	res=$($cmd)
02ddf4
 	rc=$?
02ddf4
 	if [ $rc -ne 0 ] && [ $rc -ne 2 ]; then
02ddf4
-		ocf_log err "command failed, rc $rc"
02ddf4
+		ocf_log err "command failed, rc: $rc; cmd: $cmd; result: $res"
02ddf4
 		return $OCF_ERR_GENERIC
02ddf4
 	fi
02ddf4
-
02ddf4
-	cmd="aliyuncli vpc DeleteRouteEntry --RouteTableId $OCF_RESKEY_routing_table --DestinationCidrBlock ${OCF_RESKEY_address}/32 --NextHopId $ROUTE_TO_INSTANCE --output text"
02ddf4
-	ocf_log debug "executing command: $cmd"
02ddf4
-	$cmd
02ddf4
-	if [ $? -ne 0 ]; then
02ddf4
+	request_delete_route_entry
02ddf4
+	rc=$?
02ddf4
+	if [ $rc -ne 0 ]; then
02ddf4
 		ocf_log err "command failed, rc: $rc"
02ddf4
 		return $OCF_ERR_GENERIC
02ddf4
 	fi
02ddf4
@@ -90,26 +156,18 @@
02ddf4
 }
02ddf4
 
02ddf4
 wait_for_started() {
02ddf4
-	cmd="aliyuncli vpc DescribeRouteTables --RouteTableId $OCF_RESKEY_routing_table --output text"
02ddf4
-	ocf_log debug "executing command: $cmd"
02ddf4
-	ROUTE_TO_INSTANCE="$($cmd | grep $OCF_RESKEY_address | awk '{ print $3 }')"
02ddf4
-
02ddf4
+	request_describe_route_tables
02ddf4
 	while [ "$ECS_INSTANCE_ID" != "$ROUTE_TO_INSTANCE" ]; do
02ddf4
 		sleep 3
02ddf4
-		cmd="aliyuncli vpc DescribeRouteTables --RouteTableId $OCF_RESKEY_routing_table --output text"
02ddf4
-		ocf_log debug "executing command: $cmd"
02ddf4
-		ROUTE_TO_INSTANCE="$($cmd | grep $OCF_RESKEY_address | awk '{ print $3 }')"
02ddf4
+		request_describe_route_tables
02ddf4
 	done
02ddf4
 }
02ddf4
 
02ddf4
 wait_for_deleted() {
02ddf4
-	ROUTE_TO_INSTANCE="$($cmd |grep $OCF_RESKEY_address | awk '{ print $3 }')"
02ddf4
-
02ddf4
+	request_describe_route_tables
02ddf4
 	 while [ ! -z "$ROUTE_TO_INSTANCE" ]; do
02ddf4
 		sleep 1
02ddf4
-		cmd="aliyuncli vpc DescribeRouteTables --RouteTableId $OCF_RESKEY_routing_table --output text"
02ddf4
-		ocf_log debug "executing command: $cmd"
02ddf4
-		ROUTE_TO_INSTANCE="$($cmd |grep $OCF_RESKEY_address | awk '{ print $3 }')"
02ddf4
+		request_describe_route_tables
02ddf4
 	 done
02ddf4
 }
02ddf4
 
02ddf4
@@ -124,38 +182,58 @@
02ddf4
 by changing an entry in an specific routing table
02ddf4
 </longdesc>
02ddf4
 <shortdesc lang="en">Move IP within a VPC of the Aliyun ECS</shortdesc>
02ddf4
+
02ddf4
 <parameters>
02ddf4
+<parameter name="aliyuncli" required="0">
02ddf4
+<longdesc lang="en">
02ddf4
+Path to command line tools for Aliyun
02ddf4
+</longdesc>
02ddf4
+<shortdesc lang="en">Path to Aliyun CLI tools</shortdesc>
02ddf4
+<content type="string" default="${OCF_RESKEY_aliyuncli_default}" />
02ddf4
+</parameter>
02ddf4
+
02ddf4
 <parameter name="address" required="1">
02ddf4
 <longdesc lang="en">
02ddf4
 VPC private IP address
02ddf4
 </longdesc>
02ddf4
 <shortdesc lang="en">vpc ip</shortdesc>
02ddf4
-<content type="string" default="" />
02ddf4
+<content type="string" default="${OCF_RESKEY_address_default}" />
02ddf4
 </parameter>
02ddf4
+
02ddf4
 <parameter name="routing_table" required="1">
02ddf4
 <longdesc lang="en">
02ddf4
 Name of the routing table, where the route for the IP address should be changed, i.e. vtb-...
02ddf4
 </longdesc>
02ddf4
 <shortdesc lang="en">routing table name</shortdesc>
02ddf4
-<content type="string" default="" />
02ddf4
+<content type="string" default="${OCF_RESKEY_routing_table_default}" />
02ddf4
 </parameter>
02ddf4
+
02ddf4
 <parameter name="interface" required="1">
02ddf4
 <longdesc lang="en">
02ddf4
 Name of the network interface, i.e. eth0
02ddf4
 </longdesc>
02ddf4
 <shortdesc lang="en">network interface name</shortdesc>
02ddf4
-<content type="string" default="eth0" />
02ddf4
+<content type="string" default="${OCF_RESKEY_interface_default}" />
02ddf4
 </parameter>
02ddf4
-<parameter name="profile" required="0">
02ddf4
+
02ddf4
+<parameter name="endpoint" required="0">
02ddf4
 <longdesc lang="en">
02ddf4
-Valid Aliyun CLI profile name (see 'aliyuncli-ra configure').
02ddf4
+An endpoint is the service entry of an Alibaba Cloud service, i.e. vpc.cn-beijing.aliyuncs.com
02ddf4
+</longdesc>
02ddf4
+<shortdesc lang="en">service endpoint</shortdesc>
02ddf4
+<content type="string" default="${OCF_RESKEY_endpoint_default}" />
02ddf4
+</parameter>
02ddf4
 
02ddf4
-See https://www.alibabacloud.com/help/doc-detail/43039.htm?spm=a2c63.p38356.b99.16.38a914abRZtOU3 for more information about aliyuncli-ra.
02ddf4
+<parameter name="profile" required="0">
02ddf4
+<longdesc lang="en">
02ddf4
+Valid Aliyun CLI profile name (see 'aliyun cli configure').
02ddf4
+See https://www.alibabacloud.com/help/zh/product/29991.htm for more information about aliyun cli.
02ddf4
 </longdesc>
02ddf4
 <shortdesc lang="en">profile name</shortdesc>
02ddf4
-<content type="string" default="default" />
02ddf4
+<content type="string" default="${OCF_RESKEY_profile_default}" />
02ddf4
 </parameter>
02ddf4
 </parameters>
02ddf4
+
02ddf4
 <actions>
02ddf4
 <action name="start" timeout="180s" />
02ddf4
 <action name="stop" timeout="180s" />
02ddf4
@@ -170,6 +248,11 @@
02ddf4
 ecs_ip_validate() {
02ddf4
 	ocf_log debug "function: validate"
02ddf4
 
02ddf4
+	if [ -z "${OCF_RESKEY_aliyuncli}" ]; then
02ddf4
+		ocf_exit_reason "unable to detect aliyuncli binary"
02ddf4
+		exit $OCF_ERR_INSTALLED
02ddf4
+	fi
02ddf4
+
02ddf4
 	# IP address
02ddf4
 	if [ -z "$OCF_RESKEY_address" ]; then
02ddf4
 		ocf_log err "IP address parameter not set $OCF_RESKEY_ADDRESS!"
02ddf4
@@ -250,10 +333,7 @@
02ddf4
 
02ddf4
 ecs_ip_monitor() {
02ddf4
 	ocf_log debug "function: ecsip_monitor: check routing table"
02ddf4
-	cmd="aliyuncli vpc DescribeRouteTables --RouteTableId $OCF_RESKEY_routing_table --output text"
02ddf4
-	ocf_log debug "executing command: $cmd"
02ddf4
-
02ddf4
-	ROUTE_TO_INSTANCE="$($cmd |grep $OCF_RESKEY_address | awk '{ print $3 }')"
02ddf4
+	request_describe_route_tables
02ddf4
 
02ddf4
 	if [ "$ECS_INSTANCE_ID" != "$ROUTE_TO_INSTANCE" ]; then
02ddf4
 		ocf_log debug "not routed to this instance ($ECS_INSTANCE_ID) but to instance $ROUTE_TO_INSTANCE"