vpn: consolidate nm_vpn_connection_fail() and nm_vpn_connection_disconnect()

This commit is contained in:
Dan Williams
2014-05-16 11:46:58 -05:00
parent f3c67726dc
commit b6558ecf47
4 changed files with 12 additions and 24 deletions

View File

@@ -1607,21 +1607,13 @@ nm_vpn_connection_get_ip6_internal_gateway (NMVPNConnection *connection)
}
void
nm_vpn_connection_fail (NMVPNConnection *connection,
nm_vpn_connection_stop (NMVPNConnection *connection,
gboolean fail,
NMVPNConnectionStateReason reason)
{
g_return_if_fail (NM_IS_VPN_CONNECTION (connection));
_set_vpn_state (connection, STATE_FAILED, reason);
}
void
nm_vpn_connection_disconnect (NMVPNConnection *connection,
NMVPNConnectionStateReason reason)
{
g_return_if_fail (NM_IS_VPN_CONNECTION (connection));
_set_vpn_state (connection, STATE_DISCONNECTED, reason);
_set_vpn_state (connection, fail ? STATE_FAILED : STATE_DISCONNECTED, reason);
}
gboolean
@@ -1661,7 +1653,7 @@ plugin_need_secrets_cb (DBusGProxy *proxy, DBusGProxyCall *call, void *user_dat
priv->secrets_idx + 1,
g_quark_to_string (error->domain),
error->message);
nm_vpn_connection_fail (self, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
_set_vpn_state (self, STATE_FAILED, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
g_error_free (error);
return;
}
@@ -1673,7 +1665,7 @@ plugin_need_secrets_cb (DBusGProxy *proxy, DBusGProxyCall *call, void *user_dat
nm_log_err (LOGD_VPN, "(%s/%s) final secrets request failed to provide sufficient secrets",
nm_connection_get_uuid (priv->connection),
nm_connection_get_id (priv->connection));
nm_vpn_connection_fail (self, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
_set_vpn_state (self, STATE_FAILED, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
} else {
nm_log_dbg (LOGD_VPN, "(%s/%s) service indicated additional secrets required",
nm_connection_get_uuid (priv->connection),
@@ -1705,7 +1697,7 @@ plugin_new_secrets_cb (DBusGProxy *proxy, DBusGProxyCall *call, void *user_data
nm_connection_get_id (priv->connection),
g_quark_to_string (error->domain),
error->message);
nm_vpn_connection_fail (self, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
_set_vpn_state (self, STATE_FAILED, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
g_error_free (error);
}
}
@@ -1730,7 +1722,7 @@ get_secrets_cb (NMSettingsConnection *connection,
if (error) {
nm_log_err (LOGD_VPN, "Failed to request VPN secrets #%d: (%d) %s",
priv->secrets_idx + 1, error->code, error->message);
nm_vpn_connection_fail (self, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
_set_vpn_state (self, STATE_FAILED, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
} else {
/* Cache the username for later */
if (agent_username) {
@@ -1814,7 +1806,7 @@ get_secrets (NMVPNConnection *self,
nm_log_err (LOGD_VPN, "failed to request VPN secrets #%d: (%d) %s",
priv->secrets_idx + 1, error->code, error->message);
}
nm_vpn_connection_fail (self, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
_set_vpn_state (self, STATE_FAILED, NM_VPN_CONNECTION_STATE_REASON_NO_SECRETS);
g_clear_error (&error);
}
}

View File

@@ -77,9 +77,8 @@ const char * nm_vpn_connection_get_banner (NMVPNConnection *connect
gboolean nm_vpn_connection_deactivate (NMVPNConnection *connection,
NMVPNConnectionStateReason reason);
void nm_vpn_connection_fail (NMVPNConnection *connection,
NMVPNConnectionStateReason reason);
void nm_vpn_connection_disconnect (NMVPNConnection *connection,
void nm_vpn_connection_stop (NMVPNConnection *connection,
gboolean fail,
NMVPNConnectionStateReason reason);
NMIP4Config * nm_vpn_connection_get_ip4_config (NMVPNConnection *connection);

View File

@@ -136,7 +136,7 @@ nm_vpn_manager_activate_connection (NMVPNManager *manager,
existing = find_active_vpn_connection (manager,
nm_active_connection_get_connection (NM_ACTIVE_CONNECTION (vpn)));
if (existing)
nm_vpn_connection_disconnect (vpn, NM_VPN_CONNECTION_STATE_REASON_USER_DISCONNECTED);
nm_vpn_connection_stop (vpn, FALSE, NM_VPN_CONNECTION_STATE_REASON_USER_DISCONNECTED);
return nm_vpn_service_activate (service, vpn, error);
}

View File

@@ -140,10 +140,7 @@ nm_vpn_service_connections_stop (NMVPNService *service,
NMVPNConnection *vpn = NM_VPN_CONNECTION (iter->data);
g_signal_handlers_disconnect_by_func (vpn, G_CALLBACK (connection_vpn_state_changed), service);
if (fail)
nm_vpn_connection_fail (vpn, reason);
else
nm_vpn_connection_disconnect (vpn, reason);
nm_vpn_connection_stop (vpn, fail, reason);
g_object_unref (vpn);
}
g_clear_pointer (&priv->connections, g_slist_free);