Blame SOURCES/bz2134542-IPsrcaddr-proto-metric-scope-default-route-fixes.patch

aaf9ff
From 237d55120a7c8d761f839c96651e722b3bb3bc88 Mon Sep 17 00:00:00 2001
aaf9ff
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
aaf9ff
Date: Wed, 12 Oct 2022 13:57:30 +0200
aaf9ff
Subject: [PATCH 1/4] IPsrcaddr: fix PROTO regex
aaf9ff
aaf9ff
---
aaf9ff
 heartbeat/IPsrcaddr | 2 +-
aaf9ff
 1 file changed, 1 insertion(+), 1 deletion(-)
aaf9ff
aaf9ff
diff --git a/heartbeat/IPsrcaddr b/heartbeat/IPsrcaddr
aaf9ff
index 7dbf65ff5..24406d296 100755
aaf9ff
--- a/heartbeat/IPsrcaddr
aaf9ff
+++ b/heartbeat/IPsrcaddr
aaf9ff
@@ -188,7 +188,7 @@ IPADDR="\($OCTET\.\)\{3\}$OCTET"
aaf9ff
 SRCCLAUSE="src$WS$WS*\($IPADDR\)"
aaf9ff
 MATCHROUTE="\(.*${WS}\)\($SRCCLAUSE\)\($WS.*\|$\)"
aaf9ff
 METRICCLAUSE=".*\(metric$WS[^ ]\+\)"
aaf9ff
-PROTOCLAUSE=".*\(proto$WS[^ ]\+\)"
aaf9ff
+PROTOCLAUSE=".*\(proto$WS[^ ]\+\).*"
aaf9ff
 FINDIF=findif
aaf9ff
 
aaf9ff
 # findif needs that to be set
aaf9ff
aaf9ff
From c70ba457851a401cb201cb87d23bdbc5f4fcd2b3 Mon Sep 17 00:00:00 2001
aaf9ff
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
aaf9ff
Date: Wed, 12 Oct 2022 14:00:30 +0200
aaf9ff
Subject: [PATCH 2/4] IPsrcaddr: detect metric for main table only, and allow
aaf9ff
 specifying metric if necessary
aaf9ff
aaf9ff
---
aaf9ff
 heartbeat/IPsrcaddr | 18 +++++++++++++++++-
aaf9ff
 1 file changed, 17 insertions(+), 1 deletion(-)
aaf9ff
aaf9ff
diff --git a/heartbeat/IPsrcaddr b/heartbeat/IPsrcaddr
aaf9ff
index 24406d296..4745eb8a7 100755
aaf9ff
--- a/heartbeat/IPsrcaddr
aaf9ff
+++ b/heartbeat/IPsrcaddr
aaf9ff
@@ -59,12 +59,14 @@ OCF_RESKEY_ipaddress_default=""
aaf9ff
 OCF_RESKEY_cidr_netmask_default=""
aaf9ff
 OCF_RESKEY_destination_default="0.0.0.0/0"
aaf9ff
 OCF_RESKEY_proto_default=""
aaf9ff
+OCF_RESKEY_metric_default=""
aaf9ff
 OCF_RESKEY_table_default=""
aaf9ff
 
aaf9ff
 : ${OCF_RESKEY_ipaddress=${OCF_RESKEY_ipaddress_default}}
aaf9ff
 : ${OCF_RESKEY_cidr_netmask=${OCF_RESKEY_cidr_netmask_default}}
aaf9ff
 : ${OCF_RESKEY_destination=${OCF_RESKEY_destination_default}}
aaf9ff
 : ${OCF_RESKEY_proto=${OCF_RESKEY_proto_default}}
aaf9ff
+: ${OCF_RESKEY_metric=${OCF_RESKEY_metric_default}}
aaf9ff
 : ${OCF_RESKEY_table=${OCF_RESKEY_table_default}}
aaf9ff
 #######################################################################
aaf9ff
 
aaf9ff
@@ -143,6 +145,14 @@ Proto to match when finding network. E.g. "kernel".
aaf9ff
 <content type="string" default="${OCF_RESKEY_proto_default}" />
aaf9ff
 </parameter>
aaf9ff
 
aaf9ff
+<parameter name="metric">
aaf9ff
+<longdesc lang="en">
aaf9ff
+Metric. Only needed if incorrect metric value is used.
aaf9ff
+</longdesc>
aaf9ff
+<shortdesc lang="en">Metric</shortdesc>
aaf9ff
+<content type="string" default="${OCF_RESKEY_metric_default}" />
aaf9ff
+</parameter>
aaf9ff
+
aaf9ff
 <parameter name="table">
aaf9ff
 <longdesc lang="en">
aaf9ff
 Table to modify. E.g. "local".
aaf9ff
@@ -548,8 +558,14 @@ rc=$?
aaf9ff
 
aaf9ff
 INTERFACE=`echo $findif_out | awk '{print $1}'`
aaf9ff
 LISTROUTE=`$IP2UTIL route list dev $INTERFACE scope link $PROTO match $ipaddress`
aaf9ff
-METRIC=`echo $LISTROUTE | sed -n "s/$METRICCLAUSE/\1/p"`
aaf9ff
 [ -z "$PROTO" ] && PROTO=`echo $LISTROUTE | sed -n "s/$PROTOCLAUSE/\1/p"`
aaf9ff
+if [ -n "$OCF_RESKEY_metric" ]; then
aaf9ff
+	METRIC="metric $OCF_RESKEY_metric"
aaf9ff
+elif [ -z "$TABLE" ] || [ "${TABLE#table }" = "main" ]; then
aaf9ff
+	METRIC=`echo $LISTROUTE | sed -n "s/$METRICCLAUSE/\1/p"`
aaf9ff
+else
aaf9ff
+	METRIC=""
aaf9ff
+fi
aaf9ff
 if [ "$OCF_RESKEY_destination" = "0.0.0.0/0" ] ;then
aaf9ff
 	NETWORK=`echo $LISTROUTE | grep -m 1 -o '^[^ ]*'`
aaf9ff
 
aaf9ff
aaf9ff
From c514f12f7a19440f475938f2a4659e5e9667fa25 Mon Sep 17 00:00:00 2001
aaf9ff
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
aaf9ff
Date: Wed, 12 Oct 2022 14:01:26 +0200
aaf9ff
Subject: [PATCH 3/4] IPsrcaddr: use scope host when using non-main tables
aaf9ff
aaf9ff
---
aaf9ff
 heartbeat/IPsrcaddr | 8 +++++++-
aaf9ff
 1 file changed, 7 insertions(+), 1 deletion(-)
aaf9ff
aaf9ff
diff --git a/heartbeat/IPsrcaddr b/heartbeat/IPsrcaddr
aaf9ff
index 4745eb8a7..926246008 100755
aaf9ff
--- a/heartbeat/IPsrcaddr
aaf9ff
+++ b/heartbeat/IPsrcaddr
aaf9ff
@@ -279,8 +279,14 @@ srca_stop() {
aaf9ff
 	  
aaf9ff
 	[ $rc = 2 ] && errorexit "The address you specified to stop does not match the preferred source address"
aaf9ff
 
aaf9ff
+	if [ -z "$TABLE" ] || [ "${TABLE#table }" = "main" ]; then
aaf9ff
+		SCOPE="link"
aaf9ff
+	else
aaf9ff
+		SCOPE="host"
aaf9ff
+	fi
aaf9ff
+
aaf9ff
 	PRIMARY_IP="$($IP2UTIL -4 -o addr show dev $INTERFACE primary | awk '{split($4,a,"/");print a[1]}')"
aaf9ff
-	OPTS="proto kernel scope link src $PRIMARY_IP"
aaf9ff
+	OPTS="proto kernel scope $SCOPE src $PRIMARY_IP"
aaf9ff
 
aaf9ff
 	$IP2UTIL route replace $TABLE $NETWORK dev $INTERFACE $OPTS $METRIC || \
aaf9ff
 		errorexit "command 'ip route replace $TABLE $NETWORK dev $INTERFACE $OPTS $METRIC' failed"
aaf9ff
aaf9ff
From 1f387ac8017b3eee23b41eadafd58ce21a29eb21 Mon Sep 17 00:00:00 2001
aaf9ff
From: Oyvind Albrigtsen <oalbrigt@redhat.com>
aaf9ff
Date: Thu, 13 Oct 2022 13:11:28 +0200
aaf9ff
Subject: [PATCH 4/4] IPsrcaddr: fix monitor/status for default route not being
aaf9ff
 equal to src IP before start, and change route src correctly in stop-action
aaf9ff
aaf9ff
---
aaf9ff
 heartbeat/IPsrcaddr | 5 +++--
aaf9ff
 1 file changed, 3 insertions(+), 2 deletions(-)
aaf9ff
aaf9ff
diff --git a/heartbeat/IPsrcaddr b/heartbeat/IPsrcaddr
aaf9ff
index 926246008..1bd41a930 100755
aaf9ff
--- a/heartbeat/IPsrcaddr
aaf9ff
+++ b/heartbeat/IPsrcaddr
aaf9ff
@@ -229,6 +229,7 @@ srca_read() {
aaf9ff
 
aaf9ff
 	[ -z "$SRCIP" ] && return 1
aaf9ff
 	[ $SRCIP = $1 ] && return 0
aaf9ff
+	[ "$__OCF_ACTION" = "monitor" ] || [ "$__OCF_ACTION" = "status" ] && [ "${ROUTE%% *}" = "default" ] && return 1
aaf9ff
 	return 2
aaf9ff
 }
aaf9ff
 
aaf9ff
@@ -292,8 +293,8 @@ srca_stop() {
aaf9ff
 		errorexit "command 'ip route replace $TABLE $NETWORK dev $INTERFACE $OPTS $METRIC' failed"
aaf9ff
 
aaf9ff
 	if [ "$OCF_RESKEY_destination" = "0.0.0.0/0" ] ;then
aaf9ff
-		$CMDCHANGE $ROUTE_WO_SRC || \
aaf9ff
-			errorexit "command '$CMDCHANGE $ROUTE_WO_SRC' failed"
aaf9ff
+		$CMDCHANGE $ROUTE_WO_SRC src $PRIMARY_IP || \
aaf9ff
+			errorexit "command '$CMDCHANGE $ROUTE_WO_SRC src $PRIMARY_IP' failed"
aaf9ff
 	fi
aaf9ff
 
aaf9ff
 	return $?