aboutsummaryrefslogtreecommitdiffstats
path: root/src/empathy-import-mc4-accounts.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/empathy-import-mc4-accounts.c')
-rw-r--r--src/empathy-import-mc4-accounts.c96
1 files changed, 92 insertions, 4 deletions
diff --git a/src/empathy-import-mc4-accounts.c b/src/empathy-import-mc4-accounts.c
index 6f2a02c83..df4668720 100644
--- a/src/empathy-import-mc4-accounts.c
+++ b/src/empathy-import-mc4-accounts.c
@@ -25,6 +25,7 @@
#include <glib/gi18n.h>
#include <gconf/gconf-client.h>
#include <telepathy-glib/util.h>
+#include <telepathy-glib/defs.h>
#include <dbus/dbus-protocol.h>
#include <gnome-keyring.h>
#include <libempathy/empathy-account-manager.h>
@@ -56,6 +57,11 @@ static ProfileProtocolMapItem profile_protocol_map[] =
{ "sofiasip", "sip" },
};
+typedef struct {
+ gchar *account_name;
+ gboolean enable;
+} Misc;
+
static gchar *
_account_name_from_key (const gchar *key)
{
@@ -132,12 +138,83 @@ out:
}
static void
+_move_contents (const gchar *old, const gchar *new)
+{
+ GDir *source;
+ const gchar *f;
+ int ret;
+
+ ret = g_mkdir_with_parents (new, 0777);
+ if (ret == -1)
+ return;
+
+ source = g_dir_open (old, 0, NULL);
+ if (source == NULL)
+ return;
+
+ while ((f = g_dir_read_name (source)) != NULL)
+ {
+ gchar *old_path;
+ gchar *new_path;
+
+ old_path = g_build_path (G_DIR_SEPARATOR_S, old, f, NULL);
+ new_path = g_build_path (G_DIR_SEPARATOR_S, new, f, NULL);
+
+ if (g_file_test (old_path, G_FILE_TEST_IS_DIR))
+ {
+ _move_contents (old_path, new_path);
+ }
+ else
+ {
+ GFile *f_old, *f_new;
+
+ f_old = g_file_new_for_path (old_path);
+ f_new = g_file_new_for_path (new_path);
+
+ g_file_move (f_old, f_new, G_FILE_COPY_NONE,
+ NULL, NULL, NULL, NULL);
+
+ g_object_unref (f_old);
+ g_object_unref (f_new);
+ }
+
+ g_free (old_path);
+ g_free (new_path);
+ }
+
+ g_dir_close (source);
+}
+
+static void
+_move_logs (EmpathyAccount *account, const gchar *account_name)
+{
+ gchar *old_path, *new_path, *escaped;
+ const gchar *name;
+
+ name = empathy_account_get_unique_name (account);
+ if (g_str_has_prefix (name, TP_ACCOUNT_OBJECT_PATH_BASE))
+ name += strlen (TP_ACCOUNT_OBJECT_PATH_BASE);
+
+ escaped = g_strdelimit (g_strdup (name), "/", '_');
+ new_path = g_build_path (G_DIR_SEPARATOR_S, g_get_user_data_dir (),
+ PACKAGE_NAME, "logs", escaped, NULL);
+ g_free (escaped);
+
+ old_path = g_build_path (G_DIR_SEPARATOR_S,
+ g_get_home_dir (),
+ ".gnome2", PACKAGE_NAME, "logs", account_name, NULL);
+
+ _move_contents (old_path, new_path);
+}
+
+static void
_create_account_cb (GObject *source,
GAsyncResult *result,
gpointer user_data)
{
EmpathyAccount *account;
GError *error = NULL;
+ Misc *misc = (Misc *)user_data;
if (!empathy_account_settings_apply_finish (
EMPATHY_ACCOUNT_SETTINGS (source), result, &error))
@@ -151,8 +228,14 @@ _create_account_cb (GObject *source,
DEBUG ("account created\n");
account = empathy_account_settings_get_account (
EMPATHY_ACCOUNT_SETTINGS (source));
+
+ _move_logs (account, misc->account_name);
+
empathy_account_set_enabled_async (account,
- GPOINTER_TO_INT (user_data), NULL, NULL);
+ misc->enable, NULL, NULL);
+
+ g_free (misc->account_name);
+ g_slice_free (Misc, misc);
out:
g_object_unref (source);
@@ -299,6 +382,7 @@ import_one_account (const char *path,
gchar *key;
gboolean enabled = FALSE;
gboolean ret = FALSE;
+ Misc *misc;
DEBUG ("Starting import of %s (%s)", path, account_name);
@@ -338,7 +422,6 @@ import_one_account (const char *path,
if (entries == NULL)
{
-
DEBUG ("Failed to get all entries: %s\n", error->message);
g_error_free (error);
goto failed;
@@ -349,20 +432,25 @@ import_one_account (const char *path,
key = g_strdup_printf ("%s/enabled", path);
enabled = gconf_client_get_bool (client, key, NULL);
g_free (key);
+
+ misc = g_slice_new (Misc);
+ misc->account_name = account_name;
+ misc->enable = enabled;
+
empathy_account_settings_apply_async (settings,
- _create_account_cb, GINT_TO_POINTER (enabled));
+ _create_account_cb, misc);
ret = TRUE;
out:
g_free (protocol);
g_free (profile);
g_slist_free (entries);
- g_free (account_name);
return ret;
failed:
DEBUG ("Failed to import %s", path);
+ g_free (account_name);
if (settings != NULL)
g_object_unref (settings);
goto out;