networkmanager: adapt patches for 1.46.0
While at it, add the "Upstream-Status" tag to the patches to avoid QA errors https://onedigi.atlassian.net/browse/DEL-9011 Signed-off-by: Gabriel Valcazar <gabriel.valcazar@digi.com>
This commit is contained in:
parent
cb3b03552c
commit
7125fbd222
|
|
@ -1,28 +1,30 @@
|
||||||
From: Arturo Buzarra <arturo.buzarra@digi.com>
|
From: Arturo Buzarra <arturo.buzarra@digi.com>
|
||||||
Date: Mon, 21 Jan 2019 11:30:57 +0100
|
Date: Mon, 21 Jan 2019 11:30:57 +0100
|
||||||
Subject: [PATCH] networkmanager: trigger dispatcher on per-device connectivity
|
Subject: [PATCH] networkmanager: trigger dispatcher on per-device
|
||||||
loss
|
connectivity loss
|
||||||
|
|
||||||
This creates a new dispatcher action DEVICE_CONNECTIVITY_CHANGE, that
|
This creates a new dispatcher action DEVICE_CONNECTIVITY_CHANGE, that
|
||||||
gets triggered whenever one interface fails in the upstream connectivity
|
gets triggered whenever one interface fails in the upstream connectivity
|
||||||
check, regardless of the system having connectivity through a different
|
check, regardless of the system having connectivity through a different
|
||||||
interface.
|
interface.
|
||||||
|
|
||||||
|
Upstream-Status: Inappropriate [digi specific]
|
||||||
|
|
||||||
Signed-off-by: Javier Viguera <javier.viguera@digi.com>
|
Signed-off-by: Javier Viguera <javier.viguera@digi.com>
|
||||||
Signed-off-by: Arturo Buzarra <arturo.buzarra@digi.com>
|
Signed-off-by: Arturo Buzarra <arturo.buzarra@digi.com>
|
||||||
Signed-off-by: Gabriel Valcazar <gabriel.valcazar@digi.com>
|
Signed-off-by: Gabriel Valcazar <gabriel.valcazar@digi.com>
|
||||||
---
|
---
|
||||||
src/core/devices/nm-device.c | 4 ++
|
src/core/devices/nm-device.c | 4 ++
|
||||||
src/core/nm-dispatcher.c | 48 ++++++++++++++++++-
|
src/core/nm-dispatcher.c | 45 +++++++++++++++++++
|
||||||
src/core/nm-dispatcher.h | 10 +++-
|
src/core/nm-dispatcher.h | 8 ++++
|
||||||
src/libnm-core-aux-extern/nm-dispatcher-api.h | 1 +
|
src/libnm-core-aux-extern/nm-dispatcher-api.h | 1 +
|
||||||
4 files changed, 61 insertions(+), 2 deletions(-)
|
4 files changed, 58 insertions(+)
|
||||||
|
|
||||||
diff --git a/src/core/devices/nm-device.c b/src/core/devices/nm-device.c
|
diff --git a/src/core/devices/nm-device.c b/src/core/devices/nm-device.c
|
||||||
index a11486d54be3..5ea99dc67d37 100644
|
index 34022efbde..706b41fdb3 100644
|
||||||
--- a/src/core/devices/nm-device.c
|
--- a/src/core/devices/nm-device.c
|
||||||
+++ b/src/core/devices/nm-device.c
|
+++ b/src/core/devices/nm-device.c
|
||||||
@@ -5561,6 +5561,10 @@ concheck_update_state(NMDevice *self,
|
@@ -6254,6 +6254,10 @@ concheck_update_state(NMDevice *self,
|
||||||
"connectivity state changed from %s to %s",
|
"connectivity state changed from %s to %s",
|
||||||
nm_connectivity_state_to_string(priv->concheck_x[IS_IPv4].state),
|
nm_connectivity_state_to_string(priv->concheck_x[IS_IPv4].state),
|
||||||
nm_connectivity_state_to_string(state));
|
nm_connectivity_state_to_string(state));
|
||||||
|
|
@ -34,22 +36,19 @@ index a11486d54be3..5ea99dc67d37 100644
|
||||||
|
|
||||||
_notify(self, IS_IPv4 ? PROP_IP4_CONNECTIVITY : PROP_IP6_CONNECTIVITY);
|
_notify(self, IS_IPv4 ? PROP_IP4_CONNECTIVITY : PROP_IP6_CONNECTIVITY);
|
||||||
diff --git a/src/core/nm-dispatcher.c b/src/core/nm-dispatcher.c
|
diff --git a/src/core/nm-dispatcher.c b/src/core/nm-dispatcher.c
|
||||||
index b6ff25ca45c6..aee3b6714c8c 100644
|
index 4f442c685a..ab52a6946e 100644
|
||||||
--- a/src/core/nm-dispatcher.c
|
--- a/src/core/nm-dispatcher.c
|
||||||
+++ b/src/core/nm-dispatcher.c
|
+++ b/src/core/nm-dispatcher.c
|
||||||
@@ -440,7 +440,9 @@ static const char *action_table[] = {[NM_DISPATCHER_ACTION_HOSTNAME] = NMD_
|
@@ -636,6 +636,7 @@ static const char *action_table[] = {
|
||||||
[NM_DISPATCHER_ACTION_DHCP_CHANGE_4] = NMD_ACTION_DHCP4_CHANGE,
|
[NM_DISPATCHER_ACTION_DNS_CHANGE] = NMD_ACTION_DNS_CHANGE,
|
||||||
[NM_DISPATCHER_ACTION_DHCP_CHANGE_6] = NMD_ACTION_DHCP6_CHANGE,
|
[NM_DISPATCHER_ACTION_DEVICE_ADD] = NMD_ACTION_DEVICE_ADD,
|
||||||
[NM_DISPATCHER_ACTION_CONNECTIVITY_CHANGE] =
|
[NM_DISPATCHER_ACTION_DEVICE_DELETE] = NMD_ACTION_DEVICE_DELETE,
|
||||||
- NMD_ACTION_CONNECTIVITY_CHANGE};
|
+ [NM_DISPATCHER_ACTION_DEVICE_CONNECTIVITY_CHANGE] = NMD_ACTION_DEVICE_CONNECTIVITY_CHANGE,
|
||||||
+ NMD_ACTION_CONNECTIVITY_CHANGE,
|
};
|
||||||
+ [NM_DISPATCHER_ACTION_DEVICE_CONNECTIVITY_CHANGE] =
|
|
||||||
+ NMD_ACTION_DEVICE_CONNECTIVITY_CHANGE};
|
|
||||||
|
|
||||||
static const char *
|
static const char *
|
||||||
action_to_string(NMDispatcherAction action)
|
@@ -1240,6 +1241,50 @@ nm_dispatcher_call_dns_change(void)
|
||||||
@@ -873,6 +875,50 @@ nm_dispatcher_call_connectivity(NMConnectivityState connectivity_state,
|
NULL);
|
||||||
out_call_id);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
+/**
|
+/**
|
||||||
|
|
@ -100,22 +99,20 @@ index b6ff25ca45c6..aee3b6714c8c 100644
|
||||||
nm_dispatcher_call_cancel(NMDispatcherCallId *call_id)
|
nm_dispatcher_call_cancel(NMDispatcherCallId *call_id)
|
||||||
{
|
{
|
||||||
diff --git a/src/core/nm-dispatcher.h b/src/core/nm-dispatcher.h
|
diff --git a/src/core/nm-dispatcher.h b/src/core/nm-dispatcher.h
|
||||||
index 73e0599a75f2..6b953bb6dded 100644
|
index 2882503b04..e1f484dc58 100644
|
||||||
--- a/src/core/nm-dispatcher.h
|
--- a/src/core/nm-dispatcher.h
|
||||||
+++ b/src/core/nm-dispatcher.h
|
+++ b/src/core/nm-dispatcher.h
|
||||||
@@ -21,7 +21,8 @@ typedef enum {
|
@@ -26,6 +26,7 @@ typedef enum {
|
||||||
NM_DISPATCHER_ACTION_VPN_DOWN,
|
NM_DISPATCHER_ACTION_DNS_CHANGE,
|
||||||
NM_DISPATCHER_ACTION_DHCP_CHANGE_4,
|
NM_DISPATCHER_ACTION_DEVICE_ADD,
|
||||||
NM_DISPATCHER_ACTION_DHCP_CHANGE_6,
|
NM_DISPATCHER_ACTION_DEVICE_DELETE,
|
||||||
- NM_DISPATCHER_ACTION_CONNECTIVITY_CHANGE
|
+ NM_DISPATCHER_ACTION_DEVICE_CONNECTIVITY_CHANGE,
|
||||||
+ NM_DISPATCHER_ACTION_CONNECTIVITY_CHANGE,
|
|
||||||
+ NM_DISPATCHER_ACTION_DEVICE_CONNECTIVITY_CHANGE
|
|
||||||
} NMDispatcherAction;
|
} NMDispatcherAction;
|
||||||
|
|
||||||
#define NM_DISPATCHER_ACTION_DHCP_CHANGE_X(IS_IPv4) \
|
#define NM_DISPATCHER_ACTION_DHCP_CHANGE_X(IS_IPv4) \
|
||||||
@@ -68,6 +69,13 @@ gboolean nm_dispatcher_call_connectivity(NMConnectivityState state,
|
@@ -88,6 +89,13 @@ gboolean nm_dispatcher_call_connectivity(NMConnectivityState state,
|
||||||
gpointer user_data,
|
|
||||||
NMDispatcherCallId **out_call_id);
|
gboolean nm_dispatcher_call_dns_change(void);
|
||||||
|
|
||||||
+gboolean nm_dispatcher_call_device_connectivity(NMConnectivityState
|
+gboolean nm_dispatcher_call_device_connectivity(NMConnectivityState
|
||||||
+ connectivity_state,
|
+ connectivity_state,
|
||||||
|
|
@ -128,13 +125,13 @@ index 73e0599a75f2..6b953bb6dded 100644
|
||||||
|
|
||||||
#endif /* __NM_DISPATCHER_H__ */
|
#endif /* __NM_DISPATCHER_H__ */
|
||||||
diff --git a/src/libnm-core-aux-extern/nm-dispatcher-api.h b/src/libnm-core-aux-extern/nm-dispatcher-api.h
|
diff --git a/src/libnm-core-aux-extern/nm-dispatcher-api.h b/src/libnm-core-aux-extern/nm-dispatcher-api.h
|
||||||
index 7776c84f9a4a..265fc29ee049 100644
|
index 635b4fb3a8..5b54530187 100644
|
||||||
--- a/src/libnm-core-aux-extern/nm-dispatcher-api.h
|
--- a/src/libnm-core-aux-extern/nm-dispatcher-api.h
|
||||||
+++ b/src/libnm-core-aux-extern/nm-dispatcher-api.h
|
+++ b/src/libnm-core-aux-extern/nm-dispatcher-api.h
|
||||||
@@ -33,6 +33,7 @@
|
@@ -37,6 +37,7 @@
|
||||||
#define NMD_ACTION_DHCP4_CHANGE "dhcp4-change"
|
#define NMD_ACTION_DNS_CHANGE "dns-change"
|
||||||
#define NMD_ACTION_DHCP6_CHANGE "dhcp6-change"
|
#define NMD_ACTION_DEVICE_ADD "device-add"
|
||||||
#define NMD_ACTION_CONNECTIVITY_CHANGE "connectivity-change"
|
#define NMD_ACTION_DEVICE_DELETE "device-delete"
|
||||||
+#define NMD_ACTION_DEVICE_CONNECTIVITY_CHANGE "device-connectivity-change"
|
+#define NMD_ACTION_DEVICE_CONNECTIVITY_CHANGE "device-connectivity-change"
|
||||||
|
|
||||||
typedef enum {
|
typedef enum {
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,8 @@ Instead of the 20 seconds hardcoded currently in the code, allow to
|
||||||
configure the response timeout in the connectivity section of the main
|
configure the response timeout in the connectivity section of the main
|
||||||
NetworkManager config file.
|
NetworkManager config file.
|
||||||
|
|
||||||
|
Upstream-Status: Inappropriate [digi specific]
|
||||||
|
|
||||||
Signed-off-by: Javier Viguera <javier.viguera@digi.com>
|
Signed-off-by: Javier Viguera <javier.viguera@digi.com>
|
||||||
Signed-off-by: Gabriel Valcazar <gabriel.valcazar@digi.com>
|
Signed-off-by: Gabriel Valcazar <gabriel.valcazar@digi.com>
|
||||||
---
|
---
|
||||||
|
|
@ -17,7 +19,7 @@ Signed-off-by: Gabriel Valcazar <gabriel.valcazar@digi.com>
|
||||||
5 files changed, 66 insertions(+), 1 deletion(-)
|
5 files changed, 66 insertions(+), 1 deletion(-)
|
||||||
|
|
||||||
diff --git a/src/core/nm-config-data.c b/src/core/nm-config-data.c
|
diff --git a/src/core/nm-config-data.c b/src/core/nm-config-data.c
|
||||||
index ddb7787feffa..e1774ead4090 100644
|
index 468e56b821..9e986c7233 100644
|
||||||
--- a/src/core/nm-config-data.c
|
--- a/src/core/nm-config-data.c
|
||||||
+++ b/src/core/nm-config-data.c
|
+++ b/src/core/nm-config-data.c
|
||||||
@@ -62,6 +62,7 @@ NM_GOBJECT_PROPERTIES_DEFINE_BASE(PROP_CONFIG_MAIN_FILE,
|
@@ -62,6 +62,7 @@ NM_GOBJECT_PROPERTIES_DEFINE_BASE(PROP_CONFIG_MAIN_FILE,
|
||||||
|
|
@ -36,7 +38,7 @@ index ddb7787feffa..e1774ead4090 100644
|
||||||
} connectivity;
|
} connectivity;
|
||||||
|
|
||||||
int autoconnect_retries_default;
|
int autoconnect_retries_default;
|
||||||
@@ -298,6 +300,14 @@ nm_config_data_get_connectivity_interval(const NMConfigData *self)
|
@@ -304,6 +306,14 @@ nm_config_data_get_connectivity_interval(const NMConfigData *self)
|
||||||
return NM_CONFIG_DATA_GET_PRIVATE(self)->connectivity.interval;
|
return NM_CONFIG_DATA_GET_PRIVATE(self)->connectivity.interval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -51,7 +53,7 @@ index ddb7787feffa..e1774ead4090 100644
|
||||||
const char *
|
const char *
|
||||||
nm_config_data_get_connectivity_response(const NMConfigData *self)
|
nm_config_data_get_connectivity_response(const NMConfigData *self)
|
||||||
{
|
{
|
||||||
@@ -1891,6 +1901,8 @@ nm_config_data_diff(NMConfigData *old_data, NMConfigData *new_data)
|
@@ -2006,6 +2016,8 @@ nm_config_data_diff(NMConfigData *old_data, NMConfigData *new_data)
|
||||||
!= nm_config_data_get_connectivity_enabled(new_data)
|
!= nm_config_data_get_connectivity_enabled(new_data)
|
||||||
|| nm_config_data_get_connectivity_interval(old_data)
|
|| nm_config_data_get_connectivity_interval(old_data)
|
||||||
!= nm_config_data_get_connectivity_interval(new_data)
|
!= nm_config_data_get_connectivity_interval(new_data)
|
||||||
|
|
@ -60,7 +62,7 @@ index ddb7787feffa..e1774ead4090 100644
|
||||||
|| !nm_streq0(nm_config_data_get_connectivity_uri(old_data),
|
|| !nm_streq0(nm_config_data_get_connectivity_uri(old_data),
|
||||||
nm_config_data_get_connectivity_uri(new_data))
|
nm_config_data_get_connectivity_uri(new_data))
|
||||||
|| !nm_streq0(nm_config_data_get_connectivity_response(old_data),
|
|| !nm_streq0(nm_config_data_get_connectivity_response(old_data),
|
||||||
@@ -1964,6 +1976,9 @@ get_property(GObject *object, guint prop_id, GValue *value, GParamSpec *pspec)
|
@@ -2079,6 +2091,9 @@ get_property(GObject *object, guint prop_id, GValue *value, GParamSpec *pspec)
|
||||||
case PROP_CONNECTIVITY_INTERVAL:
|
case PROP_CONNECTIVITY_INTERVAL:
|
||||||
g_value_set_uint(value, nm_config_data_get_connectivity_interval(self));
|
g_value_set_uint(value, nm_config_data_get_connectivity_interval(self));
|
||||||
break;
|
break;
|
||||||
|
|
@ -70,7 +72,7 @@ index ddb7787feffa..e1774ead4090 100644
|
||||||
case PROP_CONNECTIVITY_RESPONSE:
|
case PROP_CONNECTIVITY_RESPONSE:
|
||||||
g_value_set_string(value, nm_config_data_get_connectivity_response(self));
|
g_value_set_string(value, nm_config_data_get_connectivity_response(self));
|
||||||
break;
|
break;
|
||||||
@@ -2106,6 +2121,19 @@ constructed(GObject *object)
|
@@ -2221,6 +2236,19 @@ constructed(GObject *object)
|
||||||
NM_CONFIG_DEFAULT_CONNECTIVITY_INTERVAL);
|
NM_CONFIG_DEFAULT_CONNECTIVITY_INTERVAL);
|
||||||
g_free(str);
|
g_free(str);
|
||||||
|
|
||||||
|
|
@ -90,7 +92,7 @@ index ddb7787feffa..e1774ead4090 100644
|
||||||
priv->dns_mode = nm_strstrip(g_key_file_get_string(priv->keyfile,
|
priv->dns_mode = nm_strstrip(g_key_file_get_string(priv->keyfile,
|
||||||
NM_CONFIG_KEYFILE_GROUP_MAIN,
|
NM_CONFIG_KEYFILE_GROUP_MAIN,
|
||||||
NM_CONFIG_KEYFILE_KEY_MAIN_DNS,
|
NM_CONFIG_KEYFILE_KEY_MAIN_DNS,
|
||||||
@@ -2305,6 +2333,15 @@ nm_config_data_class_init(NMConfigDataClass *config_class)
|
@@ -2420,6 +2448,15 @@ nm_config_data_class_init(NMConfigDataClass *config_class)
|
||||||
0,
|
0,
|
||||||
G_PARAM_READABLE | G_PARAM_STATIC_STRINGS);
|
G_PARAM_READABLE | G_PARAM_STATIC_STRINGS);
|
||||||
|
|
||||||
|
|
@ -107,10 +109,10 @@ index ddb7787feffa..e1774ead4090 100644
|
||||||
g_param_spec_string(NM_CONFIG_DATA_CONNECTIVITY_RESPONSE,
|
g_param_spec_string(NM_CONFIG_DATA_CONNECTIVITY_RESPONSE,
|
||||||
"",
|
"",
|
||||||
diff --git a/src/core/nm-config-data.h b/src/core/nm-config-data.h
|
diff --git a/src/core/nm-config-data.h b/src/core/nm-config-data.h
|
||||||
index fdc7e1fc3d2b..fa7a2814819e 100644
|
index 9e7a50fc24..868e0ee4c1 100644
|
||||||
--- a/src/core/nm-config-data.h
|
--- a/src/core/nm-config-data.h
|
||||||
+++ b/src/core/nm-config-data.h
|
+++ b/src/core/nm-config-data.h
|
||||||
@@ -46,6 +46,7 @@ typedef enum {
|
@@ -47,6 +47,7 @@ typedef enum {
|
||||||
#define NM_CONFIG_DATA_CONNECTIVITY_ENABLED "connectivity-enabled"
|
#define NM_CONFIG_DATA_CONNECTIVITY_ENABLED "connectivity-enabled"
|
||||||
#define NM_CONFIG_DATA_CONNECTIVITY_URI "connectivity-uri"
|
#define NM_CONFIG_DATA_CONNECTIVITY_URI "connectivity-uri"
|
||||||
#define NM_CONFIG_DATA_CONNECTIVITY_INTERVAL "connectivity-interval"
|
#define NM_CONFIG_DATA_CONNECTIVITY_INTERVAL "connectivity-interval"
|
||||||
|
|
@ -118,7 +120,7 @@ index fdc7e1fc3d2b..fa7a2814819e 100644
|
||||||
#define NM_CONFIG_DATA_CONNECTIVITY_RESPONSE "connectivity-response"
|
#define NM_CONFIG_DATA_CONNECTIVITY_RESPONSE "connectivity-response"
|
||||||
#define NM_CONFIG_DATA_NO_AUTO_DEFAULT "no-auto-default"
|
#define NM_CONFIG_DATA_NO_AUTO_DEFAULT "no-auto-default"
|
||||||
#define NM_CONFIG_DATA_DNS_MODE "dns"
|
#define NM_CONFIG_DATA_DNS_MODE "dns"
|
||||||
@@ -171,6 +172,7 @@ char **nm_config_data_get_plugins(const NMConfigData *config_data, gboolean
|
@@ -172,6 +173,7 @@ char **nm_config_data_get_plugins(const NMConfigData *config_data, gboolean
|
||||||
gboolean nm_config_data_get_connectivity_enabled(const NMConfigData *config_data);
|
gboolean nm_config_data_get_connectivity_enabled(const NMConfigData *config_data);
|
||||||
const char *nm_config_data_get_connectivity_uri(const NMConfigData *config_data);
|
const char *nm_config_data_get_connectivity_uri(const NMConfigData *config_data);
|
||||||
guint nm_config_data_get_connectivity_interval(const NMConfigData *config_data);
|
guint nm_config_data_get_connectivity_interval(const NMConfigData *config_data);
|
||||||
|
|
@ -127,10 +129,10 @@ index fdc7e1fc3d2b..fa7a2814819e 100644
|
||||||
|
|
||||||
int nm_config_data_get_autoconnect_retries_default(const NMConfigData *config_data);
|
int nm_config_data_get_autoconnect_retries_default(const NMConfigData *config_data);
|
||||||
diff --git a/src/core/nm-config.c b/src/core/nm-config.c
|
diff --git a/src/core/nm-config.c b/src/core/nm-config.c
|
||||||
index 60a2f1df53b2..864eadd9dd6c 100644
|
index 43eb364699..20c51cb75c 100644
|
||||||
--- a/src/core/nm-config.c
|
--- a/src/core/nm-config.c
|
||||||
+++ b/src/core/nm-config.c
|
+++ b/src/core/nm-config.c
|
||||||
@@ -45,6 +45,7 @@ struct NMConfigCmdLineOptions {
|
@@ -47,6 +47,7 @@ struct NMConfigCmdLineOptions {
|
||||||
* set or not via GOptionEntry
|
* set or not via GOptionEntry
|
||||||
*/
|
*/
|
||||||
int connectivity_interval;
|
int connectivity_interval;
|
||||||
|
|
@ -138,7 +140,7 @@ index 60a2f1df53b2..864eadd9dd6c 100644
|
||||||
char *connectivity_response;
|
char *connectivity_response;
|
||||||
|
|
||||||
/* @first_start is not provided by command line. It is a convenient hack
|
/* @first_start is not provided by command line. It is a convenient hack
|
||||||
@@ -479,6 +480,7 @@ _nm_config_cmd_line_options_clear(NMConfigCmdLineOptions *cli)
|
@@ -481,6 +482,7 @@ _nm_config_cmd_line_options_clear(NMConfigCmdLineOptions *cli)
|
||||||
nm_clear_g_free(&cli->connectivity_uri);
|
nm_clear_g_free(&cli->connectivity_uri);
|
||||||
nm_clear_g_free(&cli->connectivity_response);
|
nm_clear_g_free(&cli->connectivity_response);
|
||||||
cli->connectivity_interval = -1;
|
cli->connectivity_interval = -1;
|
||||||
|
|
@ -146,7 +148,7 @@ index 60a2f1df53b2..864eadd9dd6c 100644
|
||||||
cli->first_start = FALSE;
|
cli->first_start = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -502,6 +504,7 @@ _nm_config_cmd_line_options_copy(const NMConfigCmdLineOptions *cli, NMConfigCmdL
|
@@ -504,6 +506,7 @@ _nm_config_cmd_line_options_copy(const NMConfigCmdLineOptions *cli, NMConfigCmdL
|
||||||
dst->connectivity_uri = g_strdup(cli->connectivity_uri);
|
dst->connectivity_uri = g_strdup(cli->connectivity_uri);
|
||||||
dst->connectivity_response = g_strdup(cli->connectivity_response);
|
dst->connectivity_response = g_strdup(cli->connectivity_response);
|
||||||
dst->connectivity_interval = cli->connectivity_interval;
|
dst->connectivity_interval = cli->connectivity_interval;
|
||||||
|
|
@ -154,21 +156,21 @@ index 60a2f1df53b2..864eadd9dd6c 100644
|
||||||
dst->first_start = cli->first_start;
|
dst->first_start = cli->first_start;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -652,6 +655,13 @@ nm_config_cmd_line_options_add_to_entries(NMConfigCmdLineOptions *cli, GOptionCo
|
@@ -654,6 +657,13 @@ nm_config_cmd_line_options_add_to_entries(NMConfigCmdLineOptions *cli, GOptionCo
|
||||||
&cli->connectivity_interval,
|
&cli->connectivity_interval,
|
||||||
N_("The interval between connectivity checks (in seconds)"),
|
N_("The interval between connectivity checks (in seconds)"),
|
||||||
G_STRINGIFY(NM_CONFIG_DEFAULT_CONNECTIVITY_INTERVAL)},
|
G_STRINGIFY(NM_CONFIG_DEFAULT_CONNECTIVITY_INTERVAL)},
|
||||||
+ {"connectivity-timeout",
|
+ {"connectivity-timeout",
|
||||||
+ 0,
|
+ 0,
|
||||||
+ G_OPTION_FLAG_HIDDEN,
|
+ G_OPTION_FLAG_HIDDEN,
|
||||||
+ G_OPTION_ARG_INT,
|
+ G_OPTION_ARG_INT,
|
||||||
+ &cli->connectivity_timeout,
|
+ &cli->connectivity_timeout,
|
||||||
+ N_("The timeout for the connectivity checks (in seconds)"),
|
+ N_("The timeout for the connectivity checks (in seconds)"),
|
||||||
+ G_STRINGIFY(NM_CONFIG_DEFAULT_CONNECTIVITY_TIMEOUT)},
|
+ G_STRINGIFY(NM_CONFIG_DEFAULT_CONNECTIVITY_TIMEOUT)},
|
||||||
{"connectivity-response",
|
{"connectivity-response",
|
||||||
0,
|
0,
|
||||||
G_OPTION_FLAG_HIDDEN,
|
G_OPTION_FLAG_HIDDEN,
|
||||||
@@ -1412,6 +1422,11 @@ read_entire_config(const NMConfigCmdLineOptions *cli,
|
@@ -1415,6 +1425,11 @@ read_entire_config(const NMConfigCmdLineOptions *cli,
|
||||||
NM_CONFIG_KEYFILE_GROUP_CONNECTIVITY,
|
NM_CONFIG_KEYFILE_GROUP_CONNECTIVITY,
|
||||||
"interval",
|
"interval",
|
||||||
cli->connectivity_interval);
|
cli->connectivity_interval);
|
||||||
|
|
@ -181,10 +183,10 @@ index 60a2f1df53b2..864eadd9dd6c 100644
|
||||||
g_key_file_set_string(keyfile,
|
g_key_file_set_string(keyfile,
|
||||||
NM_CONFIG_KEYFILE_GROUP_CONNECTIVITY,
|
NM_CONFIG_KEYFILE_GROUP_CONNECTIVITY,
|
||||||
diff --git a/src/core/nm-config.h b/src/core/nm-config.h
|
diff --git a/src/core/nm-config.h b/src/core/nm-config.h
|
||||||
index 2c23ff200e1d..58c8b3e67712 100644
|
index e65582c34a..8cb00e72bd 100644
|
||||||
--- a/src/core/nm-config.h
|
--- a/src/core/nm-config.h
|
||||||
+++ b/src/core/nm-config.h
|
+++ b/src/core/nm-config.h
|
||||||
@@ -26,6 +26,7 @@
|
@@ -28,6 +28,7 @@
|
||||||
#define NM_CONFIG_SIGNAL_CONFIG_CHANGED "config-changed"
|
#define NM_CONFIG_SIGNAL_CONFIG_CHANGED "config-changed"
|
||||||
|
|
||||||
#define NM_CONFIG_DEFAULT_CONNECTIVITY_INTERVAL 300
|
#define NM_CONFIG_DEFAULT_CONNECTIVITY_INTERVAL 300
|
||||||
|
|
@ -193,7 +195,7 @@ index 2c23ff200e1d..58c8b3e67712 100644
|
||||||
|
|
||||||
typedef struct NMConfigCmdLineOptions NMConfigCmdLineOptions;
|
typedef struct NMConfigCmdLineOptions NMConfigCmdLineOptions;
|
||||||
diff --git a/src/core/nm-connectivity.c b/src/core/nm-connectivity.c
|
diff --git a/src/core/nm-connectivity.c b/src/core/nm-connectivity.c
|
||||||
index 7199c9a242ad..46f5a8da1d9f 100644
|
index 15dc31aa24..f25831e300 100644
|
||||||
--- a/src/core/nm-connectivity.c
|
--- a/src/core/nm-connectivity.c
|
||||||
+++ b/src/core/nm-connectivity.c
|
+++ b/src/core/nm-connectivity.c
|
||||||
@@ -108,6 +108,7 @@ typedef struct {
|
@@ -108,6 +108,7 @@ typedef struct {
|
||||||
|
|
@ -204,24 +206,24 @@ index 7199c9a242ad..46f5a8da1d9f 100644
|
||||||
guint interval;
|
guint interval;
|
||||||
|
|
||||||
bool enabled : 1;
|
bool enabled : 1;
|
||||||
@@ -642,6 +643,7 @@ _idle_cb(gpointer user_data)
|
@@ -714,6 +715,7 @@ _idle_cb(gpointer user_data)
|
||||||
static void
|
static void
|
||||||
do_curl_request(NMConnectivityCheckHandle *cb_data)
|
do_curl_request(NMConnectivityCheckHandle *cb_data, const char *hosts)
|
||||||
{
|
{
|
||||||
+ NMConnectivityPrivate *priv = NM_CONNECTIVITY_GET_PRIVATE (cb_data->self);
|
+ NMConnectivityPrivate *priv = NM_CONNECTIVITY_GET_PRIVATE (cb_data->self);
|
||||||
CURLM *mhandle;
|
CURLM *mhandle;
|
||||||
CURL *ehandle;
|
CURL *ehandle;
|
||||||
long resolve;
|
long resolve;
|
||||||
@@ -662,7 +664,7 @@ do_curl_request(NMConnectivityCheckHandle *cb_data)
|
@@ -738,7 +740,7 @@ do_curl_request(NMConnectivityCheckHandle *cb_data, const char *hosts)
|
||||||
cb_data->concheck.curl_mhandle = mhandle;
|
cb_data->concheck.curl_mhandle = mhandle;
|
||||||
cb_data->concheck.curl_ehandle = ehandle;
|
cb_data->concheck.curl_ehandle = ehandle;
|
||||||
cb_data->concheck.request_headers = curl_slist_append(NULL, "Connection: close");
|
cb_data->concheck.request_headers = curl_slist_append(NULL, "Connection: close");
|
||||||
- cb_data->timeout_id = g_timeout_add_seconds(20, _timeout_cb, cb_data);
|
- cb_data->timeout_source = nm_g_timeout_add_seconds_source(20, _timeout_cb, cb_data);
|
||||||
+ cb_data->timeout_id = g_timeout_add_seconds(priv->timeout, _timeout_cb, cb_data);
|
+ cb_data->timeout_source = nm_g_timeout_add_seconds_source(priv->timeout, _timeout_cb, cb_data);
|
||||||
|
|
||||||
curl_multi_setopt(mhandle, CURLMOPT_SOCKETFUNCTION, multi_socket_cb);
|
curl_multi_setopt(mhandle, CURLMOPT_SOCKETFUNCTION, multi_socket_cb);
|
||||||
curl_multi_setopt(mhandle, CURLMOPT_SOCKETDATA, cb_data);
|
curl_multi_setopt(mhandle, CURLMOPT_SOCKETDATA, cb_data);
|
||||||
@@ -1044,6 +1046,7 @@ update_config(NMConnectivity *self, NMConfigData *config_data)
|
@@ -1226,6 +1228,7 @@ update_config(NMConnectivity *self, NMConfigData *config_data)
|
||||||
{
|
{
|
||||||
NMConnectivityPrivate *priv = NM_CONNECTIVITY_GET_PRIVATE(self);
|
NMConnectivityPrivate *priv = NM_CONNECTIVITY_GET_PRIVATE(self);
|
||||||
guint interval;
|
guint interval;
|
||||||
|
|
@ -229,7 +231,7 @@ index 7199c9a242ad..46f5a8da1d9f 100644
|
||||||
gboolean enabled;
|
gboolean enabled;
|
||||||
gboolean changed = FALSE;
|
gboolean changed = FALSE;
|
||||||
const char *cur_uri = priv->con_config ? priv->con_config->uri : NULL;
|
const char *cur_uri = priv->con_config ? priv->con_config->uri : NULL;
|
||||||
@@ -1130,6 +1133,13 @@ update_config(NMConnectivity *self, NMConfigData *config_data)
|
@@ -1312,6 +1315,13 @@ update_config(NMConnectivity *self, NMConfigData *config_data)
|
||||||
changed = TRUE;
|
changed = TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue