empathy r1593 - trunk/src
- From: xclaesse svn gnome org
- To: svn-commits-list gnome org
- Subject: empathy r1593 - trunk/src
- Date: Fri, 17 Oct 2008 12:45:45 +0000 (UTC)
Author: xclaesse
Date: Fri Oct 17 12:45:44 2008
New Revision: 1593
URL: http://svn.gnome.org/viewvc/empathy?rev=1593&view=rev
Log:
Added an account importer dialog. Fixes bug #541060 (Jonny Lamb)
Signed-off-by: Jonny Lamb <jonny lamb collabora co uk>
Added:
trunk/src/empathy-import-dialog.c
trunk/src/empathy-import-dialog.h
Modified:
trunk/src/Makefile.am
trunk/src/empathy-main-window.c
trunk/src/empathy-main-window.glade
Modified: trunk/src/Makefile.am
==============================================================================
--- trunk/src/Makefile.am (original)
+++ trunk/src/Makefile.am Fri Oct 17 12:45:44 2008
@@ -28,6 +28,7 @@
empathy-chatrooms-window.c empathy-chatrooms-window.h \
empathy-chat-window.c empathy-chat-window.h \
empathy-event-manager.c empathy-event-manager.h \
+ empathy-import-dialog.c empathy-import-dialog.h \
empathy-main-window.c empathy-main-window.h \
empathy-new-chatroom-dialog.c empathy-new-chatroom-dialog.h \
empathy-preferences.c empathy-preferences.h \
Added: trunk/src/empathy-import-dialog.c
==============================================================================
--- (empty file)
+++ trunk/src/empathy-import-dialog.c Fri Oct 17 12:45:44 2008
@@ -0,0 +1,406 @@
+/*
+ * Copyright (C) 2008 Collabora Ltd.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ *
+ * Authors: Jonny Lamb <jonny lamb collabora co uk>
+ * */
+
+#include <config.h>
+
+#include <string.h>
+
+#include <glib.h>
+#include <gtk/gtk.h>
+#include <glib/gi18n.h>
+
+#include <libxml/parser.h>
+#include <libxml/tree.h>
+
+#include <libmissioncontrol/mc-account.h>
+
+#include "empathy-import-dialog.h"
+
+#define DEBUG_FLAG EMPATHY_DEBUG_OTHER
+#include <libempathy/empathy-debug.h>
+
+typedef enum {
+ EMPATHY_IMPORT_SETTING_TYPE_STRING,
+ EMPATHY_IMPORT_SETTING_TYPE_BOOL,
+ EMPATHY_IMPORT_SETTING_TYPE_INT,
+} EmpathyImportSettingType;
+
+typedef struct {
+ gpointer value;
+ EmpathyImportSettingType type;
+} EmpathyImportSetting;
+
+
+/* Pidgin to MC map */
+const struct {
+ gchar *protocol;
+ gchar *pidgin_name;
+ gchar *mc_name;
+} pidgin_mc_map[] = {
+ { "msn", "server", "server" },
+ { "msn", "port", "port" },
+
+ { "jabber", "connect_server", "server" },
+ { "jabber", "port", "port" },
+ { "jabber", "require_tls", "require-encryption" },
+ { "jabber", "old_ssl", "old-ssl" },
+
+ { "aim", "server", "server" },
+ { "aim", "port", "port" },
+
+ { "salut", "first", "first-name" },
+ { "salut", "last", "last-name" },
+ { "salut", "jid", "jid" },
+ { "salut", "email", "email" },
+
+ { "groupwise", "server", "server" },
+ { "groupwise", "port", "port" },
+
+ { "icq", "server", "server" },
+ { "icq", "port", "port" },
+
+ { "irc", "realname", "fullname" },
+ { "irc", "ssl", "use-ssl" },
+ { "irc", "port", "port" },
+
+ { "yahoo", "server", "server" },
+ { "yahoo", "port", "port" },
+ { "yahoo", "xfer_port", "xfer-port" },
+ { "yahoo", "ignore_invites", "ignore-invites" },
+ { "yahoo", "yahoojp", "yahoojp" },
+ { "yahoo", "xferjp_host", "xferjp-host" },
+ { "yahoo", "serverjp", "serverjp" },
+ { "yahoo", "xfer_host", "xfer-host" },
+};
+
+#define PIDGIN_MC_MAP_ITEMS 27
+
+typedef struct {
+ GtkWidget *window;
+ GtkWidget *label_select;
+ GtkWidget *combo;
+} EmpathyImportDialog;
+
+static void empathy_import_dialog_add_setting (GHashTable *settings,
+ gchar *key,
+ gpointer value,
+ EmpathyImportSettingType type);
+static gboolean empathy_import_dialog_add_account (gchar *protocol_name,
+ GHashTable *settings);
+static void empathy_import_dialog_pidgin_parse_setting (gchar *protocol,
+ xmlNodePtr setting,
+ GHashTable *settings);
+static void empathy_import_dialog_pidgin_import_accounts ();
+static void empathy_import_dialog_response_cb (GtkDialog *dialog_window,
+ gint response,
+ EmpathyImportDialog *dialog);
+
+static EmpathyImportDialog *dialog_p = NULL;
+
+static void
+empathy_import_dialog_add_setting (GHashTable *settings,
+ gchar *key,
+ gpointer value,
+ EmpathyImportSettingType type)
+{
+ EmpathyImportSetting *set = g_new0 (EmpathyImportSetting, 1);
+
+ set->value = value;
+ set->type = type;
+
+ g_hash_table_insert (settings, key, set);
+}
+
+static gboolean
+empathy_import_dialog_add_account (gchar *protocol_name,
+ GHashTable *settings)
+{
+ McProfile *profile;
+ McAccount *account;
+
+ DEBUG ("Looking up profile with protocol '%s'", protocol_name);
+ profile = mc_profile_lookup (protocol_name);
+
+ if (profile != NULL) {
+ account = mc_account_create (profile);
+
+ if (account != NULL) {
+ const gchar *unique_name;
+ GHashTableIter iter;
+ gpointer key, value;
+ EmpathyImportSetting *set;
+
+ unique_name = mc_account_get_unique_name (account);
+ mc_account_set_display_name (account, unique_name);
+
+ g_hash_table_iter_init (&iter, settings);
+ while (g_hash_table_iter_next (&iter, &key, &value)) {
+ set = (EmpathyImportSetting *) value;
+ switch (((EmpathyImportSetting *) value)->type) {
+ case EMPATHY_IMPORT_SETTING_TYPE_STRING:
+ DEBUG ("Setting %s to (string) %s",
+ (gchar *) key, (gchar *) set->value);
+ mc_account_set_param_string (account,
+ (gchar *) key, (gchar *) set->value);
+ break;
+
+ case EMPATHY_IMPORT_SETTING_TYPE_BOOL:
+ DEBUG ("Setting %s to (bool) %i",
+ (gchar *) key, (gboolean) set->value);
+ mc_account_set_param_boolean (account,
+ (gchar *) key, (gboolean) set->value);
+ break;
+
+ case EMPATHY_IMPORT_SETTING_TYPE_INT:
+ DEBUG ("Setting %s to (int) %i",
+ (gchar *) key, (gint) set->value);
+ mc_account_set_param_int (account,
+ (gchar *) key, (gint) set->value);
+ break;
+ }
+ }
+ g_object_unref (account);
+ }
+
+ g_object_unref (profile);
+ return TRUE;
+ }
+ return FALSE;
+}
+
+static void
+empathy_import_dialog_pidgin_parse_setting (gchar *protocol,
+ xmlNodePtr setting,
+ GHashTable *settings)
+{
+ int i;
+
+ if (!xmlHasProp (setting, (xmlChar *) "name"))
+ return;
+
+ for (i = 0; i < PIDGIN_MC_MAP_ITEMS; i++) {
+ if (strcmp(protocol, pidgin_mc_map[i].protocol) != 0) {
+ continue;
+ }
+
+ if (strcmp ((gchar *) xmlGetProp (setting, (xmlChar *) "name"),
+ pidgin_mc_map[i].pidgin_name) == 0) {
+
+ int arg;
+ gchar *type = NULL;
+
+ type = (gchar *) xmlGetProp (setting, (xmlChar *) "type");
+
+ if (strcmp (type, "bool") == 0) {
+ sscanf ((gchar *) xmlNodeGetContent (setting),"%i", &arg);
+ empathy_import_dialog_add_setting (settings, pidgin_mc_map[i].mc_name,
+ (gpointer) arg,
+ EMPATHY_IMPORT_SETTING_TYPE_BOOL);
+ } else if (strcmp (type, "int") == 0) {
+ sscanf ((gchar *) xmlNodeGetContent (setting),
+ "%i", &arg);
+ empathy_import_dialog_add_setting (settings, pidgin_mc_map[i].mc_name,
+ (gpointer) arg,
+ EMPATHY_IMPORT_SETTING_TYPE_INT);
+ } else if (strcmp (type, "string") == 0) {
+ empathy_import_dialog_add_setting (settings, pidgin_mc_map[i].mc_name,
+ (gpointer) xmlNodeGetContent (setting),
+ EMPATHY_IMPORT_SETTING_TYPE_STRING);
+ }
+ }
+ }
+
+}
+
+static void
+empathy_import_dialog_pidgin_import_accounts ()
+{
+ xmlNodePtr rootnode, node, child, setting;
+ xmlParserCtxtPtr ctxt;
+ xmlDocPtr doc;
+ gchar *filename;
+ gchar *protocol = NULL;
+ gchar *name = NULL;
+ gchar *username = NULL;
+ GHashTable *settings;
+
+ ctxt = xmlNewParserCtxt ();
+
+ filename = g_build_filename (g_get_home_dir (), ".purple", "accounts.xml", NULL);
+
+ doc = xmlCtxtReadFile (ctxt, filename, NULL, 0);
+
+ g_free (filename);
+
+ rootnode = xmlDocGetRootElement (doc);
+
+ if (rootnode == NULL) {
+ return;
+ }
+
+ node = rootnode->children;
+
+ while (node) {
+ if (strcmp ((gchar *) node->name, "account") == 0) {
+ child = node->children;
+
+ settings = g_hash_table_new (g_str_hash, g_str_equal);
+
+ while (child) {
+
+ if (strcmp ((gchar *) child->name, "protocol") == 0) {
+ protocol = (gchar *) xmlNodeGetContent (child);
+
+ if (g_str_has_prefix (protocol, "prpl-")) {
+ protocol = strchr (protocol, '-') + 1;
+ }
+
+ if (strcmp (protocol, "bonjour") == 0) {
+ protocol = "salut";
+ } else if (strcmp (protocol, "novell") == 0) {
+ protocol = "groupwise";
+ }
+
+ empathy_import_dialog_add_setting (settings, "protocol",
+ (gpointer) protocol,
+ EMPATHY_IMPORT_SETTING_TYPE_STRING);
+
+ } else if (strcmp ((gchar *) child->name, "name") == 0) {
+ name = (gchar *) xmlNodeGetContent (child);
+
+ if (g_strrstr (name, "/") != NULL) {
+ gchar **name_resource;
+ name_resource = g_strsplit (name, "/", 2);
+ username = name_resource[0];
+ } else {
+ username = name;
+ }
+
+ if (strstr (name, "@") && strcmp (protocol, "irc") == 0) {
+ gchar **nick_server;
+ nick_server = g_strsplit (name, "@", 2);
+ username = nick_server[0];
+ empathy_import_dialog_add_setting (settings,
+ "server", (gpointer) nick_server[1],
+ EMPATHY_IMPORT_SETTING_TYPE_STRING);
+ }
+
+ empathy_import_dialog_add_setting (settings, "account",
+ (gpointer) username, EMPATHY_IMPORT_SETTING_TYPE_STRING);
+
+ } else if (strcmp ((gchar *) child->name, "password") == 0) {
+ empathy_import_dialog_add_setting (settings, "password",
+ (gpointer) xmlNodeGetContent (child),
+ EMPATHY_IMPORT_SETTING_TYPE_STRING);
+
+ } else if (strcmp ((gchar *) child->name, "settings") == 0) {
+
+ setting = child->children;
+
+ while (setting) {
+ empathy_import_dialog_pidgin_parse_setting (protocol,
+ setting, settings);
+ setting = setting->next;
+ }
+
+ }
+ child = child->next;
+ }
+
+ if (g_hash_table_size (settings) > 0) {
+ empathy_import_dialog_add_account (protocol, settings);
+ }
+ g_free (username);
+ g_hash_table_unref (settings);
+
+ }
+ node = node->next;
+ }
+
+ xmlFreeDoc(doc);
+ xmlFreeParserCtxt (ctxt);
+
+}
+
+static void
+empathy_import_dialog_response_cb (GtkDialog *dialog_window,
+ gint response,
+ EmpathyImportDialog *dialog)
+{
+ gchar *from = NULL;
+ if (response == GTK_RESPONSE_OK) {
+
+ from = gtk_combo_box_get_active_text (GTK_COMBO_BOX (dialog->combo));
+
+ if (strcmp (from, "Pidgin") == 0) {
+ empathy_import_dialog_pidgin_import_accounts ();
+ }
+ }
+
+ gtk_widget_destroy (GTK_WIDGET (dialog_window));
+ dialog_p = NULL;
+ g_free (dialog);
+}
+
+void
+empathy_import_dialog_show (GtkWindow *parent)
+{
+ EmpathyImportDialog *dialog;
+
+ if (dialog_p) {
+ gtk_window_present (GTK_WINDOW (dialog_p->window));
+ return;
+ }
+
+ dialog_p = dialog = g_new0 (EmpathyImportDialog, 1);
+
+ dialog->window = gtk_dialog_new_with_buttons (_("Import accounts"),
+ NULL,
+ GTK_DIALOG_MODAL | GTK_DIALOG_DESTROY_WITH_PARENT,
+ GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
+ GTK_STOCK_OK, GTK_RESPONSE_OK,
+ NULL);
+
+ g_signal_connect (G_OBJECT (dialog->window), "response",
+ G_CALLBACK (empathy_import_dialog_response_cb),
+ dialog);
+
+ dialog->label_select = gtk_label_new (_("Select the program to import accounts from:"));
+
+ dialog->combo = gtk_combo_box_new_text ();
+
+ gtk_combo_box_append_text (GTK_COMBO_BOX (dialog->combo), "Pidgin");
+ gtk_combo_box_set_active (GTK_COMBO_BOX (dialog->combo), 0);
+
+ gtk_box_pack_start_defaults (GTK_BOX (GTK_DIALOG (dialog->window)->vbox),
+ dialog->label_select);
+
+ gtk_box_pack_start_defaults (GTK_BOX (GTK_DIALOG (dialog->window)->vbox),
+ dialog->combo);
+
+
+ if (parent) {
+ gtk_window_set_transient_for (GTK_WINDOW (dialog->window),
+ parent);
+ }
+
+ gtk_widget_show_all (dialog->window);
+}
Added: trunk/src/empathy-import-dialog.h
==============================================================================
--- (empty file)
+++ trunk/src/empathy-import-dialog.h Fri Oct 17 12:45:44 2008
@@ -0,0 +1,33 @@
+/*
+ * Copyright (C) 2008 Collabora Ltd.
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program; if not, write to the
+ * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+ * Boston, MA 02111-1307, USA.
+ *
+ * Authors: Jonny Lamb <jonny lamb collabora co uk>
+ */
+
+#include <gtk/gtk.h>
+
+#ifndef __EMPATHY_IMPORT_DIALOG_H__
+#define __EMPATHY_IMPORT_DIALOG_H__
+
+G_BEGIN_DECLS
+
+void empathy_import_dialog_show (GtkWindow *parent);
+
+G_END_DECLS
+
+#endif /* __EMPATHY_IMPORT_DIALOG_H__ */
Modified: trunk/src/empathy-main-window.c
==============================================================================
--- trunk/src/empathy-main-window.c (original)
+++ trunk/src/empathy-main-window.c Fri Oct 17 12:45:44 2008
@@ -56,6 +56,7 @@
#include "empathy-new-chatroom-dialog.h"
#include "empathy-chatrooms-window.h"
#include "empathy-event-manager.h"
+#include "empathy-import-dialog.h"
#define DEBUG_FLAG EMPATHY_DEBUG_OTHER
#include <libempathy/empathy-debug.h>
@@ -133,6 +134,8 @@
EmpathyMainWindow *window);
static void main_window_chat_add_contact_cb (GtkWidget *widget,
EmpathyMainWindow *window);
+static void main_window_chat_import_cb (GtkWidget *widget,
+ EmpathyMainWindow *window);
static void main_window_chat_show_offline_cb (GtkCheckMenuItem *item,
EmpathyMainWindow *window);
static gboolean main_window_edit_button_press_event_cb (GtkWidget *widget,
@@ -421,6 +424,7 @@
"room_join_favorites", "activate", main_window_room_join_favorites_cb,
"room_manage_favorites", "activate", main_window_room_manage_favorites_cb,
"chat_add_contact", "activate", main_window_chat_add_contact_cb,
+ "chat_import", "activate", main_window_chat_import_cb,
"chat_show_offline", "toggled", main_window_chat_show_offline_cb,
"edit", "button-press-event", main_window_edit_button_press_event_cb,
"edit_accounts", "activate", main_window_edit_accounts_cb,
@@ -800,6 +804,13 @@
}
static void
+main_window_chat_import_cb (GtkWidget *widget,
+ EmpathyMainWindow *window)
+{
+ empathy_import_dialog_show (GTK_WINDOW (window->window));
+}
+
+static void
main_window_chat_show_offline_cb (GtkCheckMenuItem *item,
EmpathyMainWindow *window)
{
Modified: trunk/src/empathy-main-window.glade
==============================================================================
--- trunk/src/empathy-main-window.glade (original)
+++ trunk/src/empathy-main-window.glade Fri Oct 17 12:45:44 2008
@@ -70,6 +70,21 @@
</widget>
</child>
<child>
+ <widget class="GtkImageMenuItem" id="chat_import">
+ <property name="visible">True</property>
+ <property name="label" translatable="yes">_Import contacts...</property>
+ <property name="use_underline">True</property>
+ <accelerator key="N" modifiers="GDK_CONTROL_MASK" signal="activate"/>
+ <child internal-child="image">
+ <widget class="GtkImage" id="menu-item-image9">
+ <property name="visible">True</property>
+ <property name="stock">gtk-add</property>
+ <property name="icon_size">1</property>
+ </widget>
+ </child>
+ </widget>
+ </child>
+ <child>
<widget class="GtkSeparatorMenuItem" id="separator3">
<property name="visible">True</property>
</widget>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]