aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXavier Claessens <xavier.claessens@collabora.co.uk>2012-08-06 21:04:48 +0800
committerXavier Claessens <xavier.claessens@collabora.co.uk>2012-08-16 22:29:39 +0800
commite15e002b7371f1491507f984fe0e119b09094250 (patch)
treef75d6bb221ad001b8e5a5a1153a50e5c76ce74ec
parent92ab370c49411dede5d52f402220cc4bb0bd2e68 (diff)
downloadgsoc2013-empathy-e15e002b7371f1491507f984fe0e119b09094250.tar
gsoc2013-empathy-e15e002b7371f1491507f984fe0e119b09094250.tar.gz
gsoc2013-empathy-e15e002b7371f1491507f984fe0e119b09094250.tar.bz2
gsoc2013-empathy-e15e002b7371f1491507f984fe0e119b09094250.tar.lz
gsoc2013-empathy-e15e002b7371f1491507f984fe0e119b09094250.tar.xz
gsoc2013-empathy-e15e002b7371f1491507f984fe0e119b09094250.tar.zst
gsoc2013-empathy-e15e002b7371f1491507f984fe0e119b09094250.zip
migrate existing TP accounts to libaccounts
https://bugzilla.gnome.org/show_bug.cgi?id=680774
-rw-r--r--src/empathy-sanity-cleaning.c111
1 files changed, 110 insertions, 1 deletions
diff --git a/src/empathy-sanity-cleaning.c b/src/empathy-sanity-cleaning.c
index 7437be47d..9497695aa 100644
--- a/src/empathy-sanity-cleaning.c
+++ b/src/empathy-sanity-cleaning.c
@@ -27,6 +27,7 @@
#include <telepathy-glib/telepathy-glib.h>
+#include <libempathy/empathy-account-settings.h>
#include <libempathy/empathy-gsettings.h>
#include <libempathy-gtk/empathy-theme-manager.h>
@@ -40,7 +41,7 @@
* If the number stored in gsettings is lower than it, all the tasks will
* be executed.
*/
-#define SANITY_CLEANING_NUMBER 3
+#define SANITY_CLEANING_NUMBER 4
static void
account_update_parameters_cb (GObject *source,
@@ -198,6 +199,111 @@ finally:
g_object_unref (gsettings_chat);
}
+#ifdef HAVE_UOA
+static void
+uoa_account_created_cb (GObject *source,
+ GAsyncResult *result,
+ gpointer user_data)
+{
+ TpAccountRequest *ar = (TpAccountRequest *) source;
+ TpAccount *old_account = user_data;
+ TpAccount *new_account;
+ GError *error = NULL;
+
+ new_account = tp_account_request_create_account_finish (ar, result, &error);
+ if (new_account == NULL)
+ {
+ DEBUG ("Failed to migrate account '%s' to UOA: %s",
+ tp_account_get_path_suffix (old_account), error->message);
+ g_clear_error (&error);
+ }
+ else
+ {
+ DEBUG ("New account %s created to superseed %s",
+ tp_account_get_path_suffix (new_account),
+ tp_account_get_path_suffix (old_account));
+ tp_account_remove_async (old_account, NULL, NULL);
+ }
+
+ g_object_unref (old_account);
+ g_object_unref (new_account);
+}
+
+static void
+migrate_accounts_to_uoa (TpAccountManager *am)
+{
+ GList *accounts, *l;
+
+ DEBUG ("Start migrating accounts to UOA");
+
+ accounts = tp_account_manager_get_valid_accounts (am);
+ for (l = accounts; l != NULL; l = g_list_next (l))
+ {
+ TpAccount *account = l->data;
+ TpAccountRequest *ar;
+ GVariant *params;
+ GVariant *param;
+ GVariantIter iter;
+ const gchar * const *supersedes;
+
+ /* If account is already in a specific storage (like UOA or GOA),
+ * don't migrate it.
+ * Note that we cannot migrate GOA accounts anyway, since we can't delete
+ * them it would create duplicated accounts. */
+ if (!tp_str_empty (tp_account_get_storage_provider (account)))
+ continue;
+
+ DEBUG ("Migrating account %s to UOA storage\n",
+ tp_account_get_path_suffix (account));
+
+ ar = tp_account_request_new (am,
+ tp_account_get_cm_name (account),
+ tp_account_get_protocol_name (account),
+ tp_account_get_display_name (account));
+ tp_account_request_set_storage_provider (ar, EMPATHY_UOA_PROVIDER);
+ tp_account_request_set_enabled (ar,
+ tp_account_is_enabled (account));
+ tp_account_request_set_icon_name (ar,
+ tp_account_get_icon_name (account));
+ tp_account_request_set_nickname (ar,
+ tp_account_get_nickname (account));
+ tp_account_request_set_service (ar,
+ tp_account_get_service (account));
+
+ supersedes = tp_account_get_supersedes (account);
+ while (*supersedes != NULL)
+ tp_account_request_add_supersedes (ar, *supersedes);
+ tp_account_request_add_supersedes (ar,
+ tp_proxy_get_object_path (account));
+
+ params = tp_account_dup_parameters_vardict (account);
+ g_variant_iter_init (&iter, params);
+ while ((param = g_variant_iter_next_value (&iter)))
+ {
+ GVariant *k, *v;
+ const gchar *key;
+
+ k = g_variant_get_child_value (param, 0);
+ key = g_variant_get_string (k, NULL);
+ v = g_variant_get_child_value (param, 1);
+
+ tp_account_request_set_parameter (ar, key,
+ g_variant_get_variant (v));
+
+ g_variant_unref (k);
+ g_variant_unref (v);
+ }
+
+ tp_account_set_enabled_async (account, FALSE, NULL, NULL);
+ tp_account_request_create_account_async (ar, uoa_account_created_cb,
+ g_object_ref (account));
+
+ g_variant_unref (params);
+ g_object_unref (ar);
+ }
+}
+#endif
+
static void
run_sanity_cleaning_tasks (TpAccountManager *am)
{
@@ -206,6 +312,9 @@ run_sanity_cleaning_tasks (TpAccountManager *am)
fix_xmpp_account_priority (am);
set_facebook_account_fallback_server (am);
upgrade_chat_theme_settings ();
+#ifdef HAVE_UOA
+ migrate_accounts_to_uoa (am);
+#endif
}
static void