aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--libempathy/empathy-account-settings.c46
1 files changed, 21 insertions, 25 deletions
diff --git a/libempathy/empathy-account-settings.c b/libempathy/empathy-account-settings.c
index 7e3a745be..f88ff3dd7 100644
--- a/libempathy/empathy-account-settings.c
+++ b/libempathy/empathy-account-settings.c
@@ -536,7 +536,6 @@ static void
empathy_account_settings_check_readyness (EmpathyAccountSettings *self)
{
EmpathyAccountSettingsPriv *priv = GET_PRIV (self);
- const TpConnectionManagerProtocol *tp_protocol;
GQuark features[] = { TP_PROTOCOL_FEATURE_CORE, 0 };
if (priv->ready)
@@ -573,34 +572,11 @@ empathy_account_settings_check_readyness (EmpathyAccountSettings *self)
priv->uri_scheme_tel = empathy_account_has_uri_scheme_tel (priv->account);
}
- tp_protocol = tp_connection_manager_get_protocol (priv->manager,
- priv->protocol);
-
- if (tp_protocol == NULL)
- {
- tp_clear_object (&priv->manager);
- return;
- }
-
- if (priv->required_params == NULL)
- {
- TpConnectionManagerParam *cur;
-
- for (cur = tp_protocol->params; cur->name != NULL; cur++)
- {
- if (tp_connection_manager_param_is_required (cur))
- {
- priv->required_params = g_list_append (priv->required_params,
- g_strdup (cur->name));
- }
- }
- }
-
if (priv->protocol_obj == NULL)
{
priv->protocol_obj = g_object_ref (
tp_connection_manager_get_protocol_object (priv->manager,
- priv->protocol));
+ priv->protocol));
}
if (!tp_proxy_is_prepared (priv->protocol_obj, TP_PROTOCOL_FEATURE_CORE)
@@ -621,6 +597,26 @@ empathy_account_settings_check_readyness (EmpathyAccountSettings *self)
}
}
+ if (priv->required_params == NULL)
+ {
+ GList *params, *l;
+
+ params = tp_protocol_dup_params (priv->protocol_obj);
+ for (l = params; l != NULL; l = g_list_next (l))
+ {
+ TpConnectionManagerParam *cur = l->data;
+
+ if (tp_connection_manager_param_is_required (cur))
+ {
+ priv->required_params = g_list_append (priv->required_params,
+ g_strdup (cur->name));
+ }
+ }
+
+ g_list_free_full (params,
+ (GDestroyNotify) tp_connection_manager_param_free);
+ }
+
/* NOTE: When removing MC migration code, remove this call, and the
* function it's calling. That's it. */
empathy_account_settings_try_migrating_password (self);