Blame SOURCES/bz1582685-IPsrcaddr-3-fix-probe-issues.patch

011c77
From 7afc581f6cd8fc37c3e14ece12fb16d31f1886f9 Mon Sep 17 00:00:00 2001
011c77
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
011c77
Date: Fri, 10 Jan 2020 14:35:56 +0100
011c77
Subject: [PATCH] IPsrcaddr: fixes to avoid failing during probe
011c77
011c77
---
011c77
 heartbeat/IPsrcaddr | 11 ++++++++++-
011c77
 1 file changed, 10 insertions(+), 1 deletion(-)
011c77
011c77
diff --git a/heartbeat/IPsrcaddr b/heartbeat/IPsrcaddr
011c77
index f9085f082..0ef8b391f 100755
011c77
--- a/heartbeat/IPsrcaddr
011c77
+++ b/heartbeat/IPsrcaddr
011c77
@@ -75,6 +75,10 @@ USAGE="usage: $0 {start|stop|status|monitor|validate-all|meta-data}";
011c77
   CMDSHOW="$IP2UTIL route show   $TABLE to exact $OCF_RESKEY_destination"
011c77
 CMDCHANGE="$IP2UTIL route change to "
011c77
 
011c77
+if [ "$OCF_RESKEY_destination" != "0.0.0.0/0" ]; then
011c77
+	CMDSHOW="$CMDSHOW src $OCF_RESKEY_ipaddress"
011c77
+fi
011c77
+
011c77
 if [ "$OCF_RESKEY_table" = "local" ]; then
011c77
 	TABLE="$TABLE local"
011c77
 fi
011c77
@@ -183,7 +187,7 @@ export OCF_RESKEY_ip=$OCF_RESKEY_ipaddress
011c77
 
011c77
 srca_read() {
011c77
 	# Capture matching route - doublequotes prevent word splitting...
011c77
-	ROUTE="`$CMDSHOW`" || errorexit "command '$CMDSHOW' failed"
011c77
+	ROUTE="`$CMDSHOW 2> /dev/null`" || errorexit "command '$CMDSHOW' failed"
011c77
 
011c77
 	# ... so we can make sure there is only 1 matching route
011c77
 	[ 1 -eq `echo "$ROUTE" | wc -l` ] || \
011c77
@@ -199,6 +203,11 @@ srca_read() {
011c77
 	# and what remains after stripping out the source ip address clause
011c77
 	ROUTE_WO_SRC=`echo $ROUTE | sed "s/$MATCHROUTE/\1\5/"`
011c77
 
011c77
+	# using "src <ip>" only returns output if there's a match
011c77
+	if [ "$OCF_RESKEY_destination" != "0.0.0.0/0" ]; then
011c77
+		[ -z "$ROUTE" ] && return 1 || return 0
011c77
+	fi
011c77
+
011c77
 	[ -z "$SRCIP" ] && return 1
011c77
 	[ $SRCIP = $1 ] && return 0
011c77
 	return 2