policy: block connection from autoconnect in case of failed dependency

A connection that fails due to dependency-failed is not able to
reconnect until the master connection activates again; when this
happens, the master clears the blocked reason for all its slaves in
activate_slave_connections() and tries to reconnect them. For this to
work, the slave should be marked as blocked when it fails with
dependency-failed.
This commit is contained in:
Beniamino Galvani
2020-07-16 11:58:20 +02:00
parent fe2d93980b
commit 725fed01cf

View File

@@ -1787,7 +1787,7 @@ device_state_changed (NMDevice *device,
if ( sett_conn if ( sett_conn
&& old_state >= NM_DEVICE_STATE_PREPARE && old_state >= NM_DEVICE_STATE_PREPARE
&& old_state <= NM_DEVICE_STATE_ACTIVATED) { && old_state <= NM_DEVICE_STATE_ACTIVATED) {
gboolean block_no_secrets = FALSE; gboolean blocked = FALSE;
int tries; int tries;
guint64 con_v; guint64 con_v;
@@ -1807,15 +1807,32 @@ device_state_changed (NMDevice *device,
*/ */
con_v = nm_settings_connection_get_last_secret_agent_version_id (sett_conn); con_v = nm_settings_connection_get_last_secret_agent_version_id (sett_conn);
if ( con_v == 0 if ( con_v == 0
|| con_v == nm_agent_manager_get_agent_version_id (priv->agent_mgr)) || con_v == nm_agent_manager_get_agent_version_id (priv->agent_mgr)) {
block_no_secrets = TRUE; _LOGD (LOGD_DEVICE, "connection '%s' now blocked from autoconnect due to no secrets",
nm_settings_connection_get_id (sett_conn));
nm_settings_connection_autoconnect_blocked_reason_set (sett_conn,
NM_SETTINGS_AUTO_CONNECT_BLOCKED_REASON_NO_SECRETS,
TRUE);
blocked = TRUE;
}
} else if (nm_device_state_reason_check (reason) == NM_DEVICE_STATE_REASON_DEPENDENCY_FAILED) {
/* A connection that fails due to dependency-failed is not
* able to reconnect until the master connection activates
* again; when this happens, the master clears the blocked
* reason for all its slaves in activate_slave_connections()
* and tries to reconnect them. For this to work, the slave
* should be marked as blocked when it fails with
* dependency-failed.
*/
_LOGD (LOGD_DEVICE, "connection '%s' now blocked from autoconnect due to failed dependency",
nm_settings_connection_get_id (sett_conn));
nm_settings_connection_autoconnect_blocked_reason_set (sett_conn,
NM_SETTINGS_AUTO_CONNECT_BLOCKED_REASON_FAILED,
TRUE);
blocked = TRUE;
} }
if (block_no_secrets) { if (!blocked) {
_LOGD (LOGD_DEVICE, "connection '%s' now blocked from autoconnect due to no secrets",
nm_settings_connection_get_id (sett_conn));
nm_settings_connection_autoconnect_blocked_reason_set (sett_conn, NM_SETTINGS_AUTO_CONNECT_BLOCKED_REASON_NO_SECRETS, TRUE);
} else {
tries = nm_settings_connection_autoconnect_retries_get (sett_conn); tries = nm_settings_connection_autoconnect_retries_get (sett_conn);
if (tries > 0) { if (tries > 0) {
_LOGD (LOGD_DEVICE, "connection '%s' failed to autoconnect; %d tries left", _LOGD (LOGD_DEVICE, "connection '%s' failed to autoconnect; %d tries left",