aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/empathy-sanity-cleaning.c43
1 files changed, 42 insertions, 1 deletions
diff --git a/src/empathy-sanity-cleaning.c b/src/empathy-sanity-cleaning.c
index 740d84206..70e5de273 100644
--- a/src/empathy-sanity-cleaning.c
+++ b/src/empathy-sanity-cleaning.c
@@ -38,7 +38,7 @@
* If the number stored in gsettings is lower than it, all the tasks will
* be executed.
*/
-#define SANITY_CLEANING_NUMBER 1
+#define SANITY_CLEANING_NUMBER 2
static void
account_update_parameters_cb (GObject *source,
@@ -101,11 +101,52 @@ fix_xmpp_account_priority (TpAccountManager *am)
}
static void
+set_facebook_account_fallback_server (TpAccountManager *am)
+{
+ GList *accounts, *l;
+
+ accounts = tp_account_manager_get_valid_accounts (am);
+ for (l = accounts; l != NULL; l = g_list_next (l))
+ {
+ TpAccount *account = l->data;
+ GHashTable *params;
+ gchar *fallback_servers[] = {
+ "chat.facebook.com:443",
+ NULL };
+
+ if (tp_strdiff (tp_account_get_service (account), "facebook"))
+ continue;
+
+ params = (GHashTable *) tp_account_get_parameters (account);
+ if (params == NULL)
+ continue;
+
+ if (tp_asv_get_strv (params, "fallback-servers") != NULL)
+ continue;
+
+ DEBUG ("Setting chat.facebook.com:443 as a fallback on account '%s'",
+ tp_account_get_path_suffix (account));
+
+ params = tp_asv_new (
+ "fallback-servers", G_TYPE_STRV, fallback_servers,
+ NULL);
+
+ tp_account_update_parameters_async (account, params, NULL,
+ account_update_parameters_cb, NULL);
+
+ g_hash_table_unref (params);
+ }
+
+ g_list_free (accounts);
+}
+
+static void
run_sanity_cleaning_tasks (TpAccountManager *am)
{
DEBUG ("Starting sanity cleaning tasks");
fix_xmpp_account_priority (am);
+ set_facebook_account_fallback_server (am);
}
static void