Blame SOURCES/0025-team-clean-runner-tx-hash-on-set-rh1541922.patch

013a0d
From 01d1f64ad408947fbeaebbf2768828504044377f Mon Sep 17 00:00:00 2001
013a0d
From: Francesco Giudici <fgiudici@redhat.com>
013a0d
Date: Mon, 5 Feb 2018 17:50:33 +0100
013a0d
Subject: [PATCH 1/2] nmcli: team: clear runner-tx-hash before adding new
013a0d
 hashes
013a0d
013a0d
https://bugzilla.redhat.com/show_bug.cgi?id=1541922
013a0d
(cherry picked from commit 350dbb55abf3a80267c398e6f64c2cee4645475a)
013a0d
---
013a0d
 clients/common/nm-meta-setting-desc.c | 3 +++
013a0d
 1 file changed, 3 insertions(+)
013a0d
013a0d
diff --git a/clients/common/nm-meta-setting-desc.c b/clients/common/nm-meta-setting-desc.c
013a0d
index d829fa7d4..85b272cbc 100644
013a0d
--- a/clients/common/nm-meta-setting-desc.c
013a0d
+++ b/clients/common/nm-meta-setting-desc.c
013a0d
@@ -3976,6 +3976,9 @@ _set_fcn_team_runner_tx_hash (ARGS_SET_FCN)
013a0d
 		return FALSE;
013a0d
 	}
013a0d
 
013a0d
+	while (nm_setting_team_get_num_runner_tx_hash (NM_SETTING_TEAM (setting)))
013a0d
+		nm_setting_team_remove_runner_tx_hash (NM_SETTING_TEAM (setting), 0);
013a0d
+
013a0d
 	while (strv && strv[i])
013a0d
 		nm_setting_team_add_runner_tx_hash (NM_SETTING_TEAM (setting), strv[i++]);
013a0d
 	g_strfreev (strv);
013a0d
-- 
013a0d
2.14.3
013a0d
013a0d
013a0d
From 11f0ca1f23e000e7cbd246a176d8470c8b6ee8a6 Mon Sep 17 00:00:00 2001
013a0d
From: Francesco Giudici <fgiudici@redhat.com>
013a0d
Date: Tue, 6 Feb 2018 16:44:11 +0100
013a0d
Subject: [PATCH 2/2] nmcli: team: do strict checking on runner-tx-hashes
013a0d
013a0d
Substrings matching the heading of valid values were allowed if not
013a0d
ambiguous (e.g.: "et" for "eth"). Moreover, upper case variants were
013a0d
accepted too.
013a0d
Do a plain string comparison check against the valid values.
013a0d
Improve also the error message: give a list of valid tx-hashes.
013a0d
013a0d
(cherry picked from commit fd5b3f802ec204392ada9ee9b75978059323fab4)
013a0d
---
013a0d
 clients/common/nm-meta-setting-desc.c | 31 +++++++++++++++++++------------
013a0d
 1 file changed, 19 insertions(+), 12 deletions(-)
013a0d
013a0d
diff --git a/clients/common/nm-meta-setting-desc.c b/clients/common/nm-meta-setting-desc.c
013a0d
index 85b272cbc..94404e908 100644
013a0d
--- a/clients/common/nm-meta-setting-desc.c
013a0d
+++ b/clients/common/nm-meta-setting-desc.c
013a0d
@@ -3950,12 +3950,19 @@ _validate_fcn_team_config (const char *value, char **out_to_free, GError **error
013a0d
 }
013a0d
 
013a0d
 static gboolean
013a0d
-_is_valid_team_runner_tx_hash_element (const char *tx_hash_element)
013a0d
+_is_valid_team_runner_tx_hash_element (const char *tx_hash_element,
013a0d
+                                       GError **error)
013a0d
 {
013a0d
-	const char *valid_tx_hashes[] = { "eth", "vlan", "ipv4", "ipv6", "ip",
013a0d
-	                                  "l3", "tcp", "udp", "sctp", "l4", NULL };
013a0d
-	if (nmc_string_is_valid (tx_hash_element, valid_tx_hashes, NULL))
013a0d
+	nm_assert (!error || !*error);
013a0d
+
013a0d
+	if (NM_IN_STRSET (tx_hash_element,
013a0d
+	                  "eth", "vlan", "ipv4", "ipv6", "ip",
013a0d
+	                  "l3", "tcp", "udp", "sctp", "l4")) {
013a0d
 		return TRUE;
013a0d
+	}
013a0d
+
013a0d
+	g_set_error (error, 1, 0, "'%s' is not valid. %s", tx_hash_element,
013a0d
+	             "Valid tx-hashes: [eth, vlan, ipv4, ipv6, ip, l3, tcp, udp, sctp, l4]");
013a0d
 	return FALSE;
013a0d
 }
013a0d
 
013a0d
@@ -3963,24 +3970,24 @@ static gboolean
013a0d
 _set_fcn_team_runner_tx_hash (ARGS_SET_FCN)
013a0d
 {
013a0d
 	char **strv = NULL;
013a0d
-	guint i = 0;
013a0d
+	char *const*iter;
013a0d
 
013a0d
 	g_return_val_if_fail (error == NULL || *error == NULL, FALSE);
013a0d
 
013a0d
 	strv = _nm_utils_strv_cleanup (g_strsplit_set (value, " \t,", 0),
013a0d
 	                               TRUE, TRUE, TRUE);
013a0d
-	if (!verify_string_list (strv, property_info->property_name,
013a0d
-	                         _is_valid_team_runner_tx_hash_element,
013a0d
-	                         error)) {
013a0d
-		g_strfreev (strv);
013a0d
-		return FALSE;
013a0d
+	for (iter = strv; strv && *iter; iter++) {
013a0d
+		if (!_is_valid_team_runner_tx_hash_element (*iter, error)) {
013a0d
+			g_strfreev (strv);
013a0d
+			return FALSE;
013a0d
+		}
013a0d
 	}
013a0d
 
013a0d
 	while (nm_setting_team_get_num_runner_tx_hash (NM_SETTING_TEAM (setting)))
013a0d
 		nm_setting_team_remove_runner_tx_hash (NM_SETTING_TEAM (setting), 0);
013a0d
 
013a0d
-	while (strv && strv[i])
013a0d
-		nm_setting_team_add_runner_tx_hash (NM_SETTING_TEAM (setting), strv[i++]);
013a0d
+	for (iter = strv; strv && *iter; iter++)
013a0d
+		nm_setting_team_add_runner_tx_hash (NM_SETTING_TEAM (setting), *iter);
013a0d
 	g_strfreev (strv);
013a0d
 
013a0d
 	return TRUE;
013a0d
-- 
013a0d
2.14.3
013a0d