aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXavier Claessens <xavier.claessens@collabora.co.uk>2012-08-24 19:13:07 +0800
committerXavier Claessens <xavier.claessens@collabora.co.uk>2012-08-27 21:47:21 +0800
commitc3933b7972672e533c33cf9f401a1dea83ba1368 (patch)
tree80957d6c8a7244c33d7fdc50bbc6e3a5e8f3b60e
parent1b787a9f326fa5d4224f1a0fe7be56f455b2eedd (diff)
downloadgsoc2013-empathy-c3933b7972672e533c33cf9f401a1dea83ba1368.tar
gsoc2013-empathy-c3933b7972672e533c33cf9f401a1dea83ba1368.tar.gz
gsoc2013-empathy-c3933b7972672e533c33cf9f401a1dea83ba1368.tar.bz2
gsoc2013-empathy-c3933b7972672e533c33cf9f401a1dea83ba1368.tar.lz
gsoc2013-empathy-c3933b7972672e533c33cf9f401a1dea83ba1368.tar.xz
gsoc2013-empathy-c3933b7972672e533c33cf9f401a1dea83ba1368.tar.zst
gsoc2013-empathy-c3933b7972672e533c33cf9f401a1dea83ba1368.zip
UOA: Use an AgManager singleton
This is especially useful in empathy-keyring where it would reload all accounts each time we set a password. https://bugzilla.gnome.org/show_bug.cgi?id=680776
-rw-r--r--libempathy/Makefile.am2
-rw-r--r--libempathy/empathy-uoa-auth-handler.c7
-rw-r--r--libempathy/empathy-uoa-utils.c49
-rw-r--r--libempathy/empathy-uoa-utils.h35
-rw-r--r--ubuntu-online-accounts/cc-plugins/empathy-accounts-plugin.c7
5 files changed, 95 insertions, 5 deletions
diff --git a/libempathy/Makefile.am b/libempathy/Makefile.am
index 2274b99ed..36de4d6c2 100644
--- a/libempathy/Makefile.am
+++ b/libempathy/Makefile.am
@@ -104,6 +104,8 @@ goa_sources = \
uoa_sources = \
empathy-uoa-auth-handler.c \
empathy-uoa-auth-handler.h \
+ empathy-uoa-utils.c \
+ empathy-uoa-utils.h \
$(NULL)
pkglib_LTLIBRARIES = libempathy.la
diff --git a/libempathy/empathy-uoa-auth-handler.c b/libempathy/empathy-uoa-auth-handler.c
index d1b046512..9b1eade10 100644
--- a/libempathy/empathy-uoa-auth-handler.c
+++ b/libempathy/empathy-uoa-auth-handler.c
@@ -33,10 +33,9 @@
#include "empathy-debug.h"
#include "empathy-utils.h"
#include "empathy-uoa-auth-handler.h"
+#include "empathy-uoa-utils.h"
#include "empathy-sasl-mechanisms.h"
-#define SERVICE_TYPE "IM"
-
struct _EmpathyUoaAuthHandlerPriv
{
AgManager *manager;
@@ -50,7 +49,7 @@ empathy_uoa_auth_handler_init (EmpathyUoaAuthHandler *self)
self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
EMPATHY_TYPE_UOA_AUTH_HANDLER, EmpathyUoaAuthHandlerPriv);
- self->priv->manager = ag_manager_new_for_service_type (SERVICE_TYPE);
+ self->priv->manager = empathy_uoa_manager_dup ();
}
static void
@@ -259,7 +258,7 @@ empathy_uoa_auth_handler_start (EmpathyUoaAuthHandler *self,
account = ag_manager_get_account (self->priv->manager, id);
if (account != NULL)
- l = ag_account_list_services_by_type (account, SERVICE_TYPE);
+ l = ag_account_list_services_by_type (account, EMPATHY_UOA_SERVICE_TYPE);
if (l == NULL)
{
DEBUG ("Couldn't find IM service for AgAccountId %u", id);
diff --git a/libempathy/empathy-uoa-utils.c b/libempathy/empathy-uoa-utils.c
new file mode 100644
index 000000000..f63a15193
--- /dev/null
+++ b/libempathy/empathy-uoa-utils.c
@@ -0,0 +1,49 @@
+/*
+ * empathy-uoa-utils.c - Source for UOA utilities
+ * Copyright (C) 2012 Collabora Ltd.
+ * @author Xavier Claessens <xavier.claessens@collabora.co.uk>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#include "config.h"
+
+#define DEBUG_FLAG EMPATHY_DEBUG_ACCOUNT
+#include "empathy-debug.h"
+#include "empathy-uoa-utils.h"
+
+static AgManager *singleton = NULL;
+
+void
+empathy_uoa_manager_set_default (AgManager *manager)
+{
+ if (singleton != NULL)
+ return;
+
+ singleton = manager;
+ g_object_add_weak_pointer ((GObject *) singleton, (gpointer) &singleton);
+}
+
+AgManager *
+empathy_uoa_manager_dup (void)
+{
+ if (singleton != NULL)
+ return g_object_ref (singleton);
+
+ singleton = ag_manager_new_for_service_type (EMPATHY_UOA_SERVICE_TYPE);
+ g_object_add_weak_pointer ((GObject *) singleton, (gpointer) &singleton);
+
+ return singleton;
+}
diff --git a/libempathy/empathy-uoa-utils.h b/libempathy/empathy-uoa-utils.h
new file mode 100644
index 000000000..2cd7a41a2
--- /dev/null
+++ b/libempathy/empathy-uoa-utils.h
@@ -0,0 +1,35 @@
+/*
+ * empathy-utils.h - Header for UOA utilities
+ * Copyright (C) 2012 Collabora Ltd.
+ * @author Xavier Claessens <xavier.claessens@collabora.co.uk>
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
+ */
+
+#ifndef __EMPATHY_UOA_UTILS_H__
+#define __EMPATHY_UOA_UTILS_H__
+
+#include <libaccounts-glib/ag-manager.h>
+
+#define EMPATHY_UOA_SERVICE_TYPE "IM"
+
+G_BEGIN_DECLS
+
+void empathy_uoa_manager_set_default (AgManager *manager);
+AgManager *empathy_uoa_manager_dup (void);
+
+G_END_DECLS
+
+#endif /* #ifndef __EMPATHY_UOA_UTILS_H__*/
diff --git a/ubuntu-online-accounts/cc-plugins/empathy-accounts-plugin.c b/ubuntu-online-accounts/cc-plugins/empathy-accounts-plugin.c
index 7431abc08..939912aad 100644
--- a/ubuntu-online-accounts/cc-plugins/empathy-accounts-plugin.c
+++ b/ubuntu-online-accounts/cc-plugins/empathy-accounts-plugin.c
@@ -23,6 +23,7 @@
#include "empathy-accounts-plugin.h"
#include <libempathy/empathy-client-factory.h>
+#include <libempathy/empathy-uoa-utils.h>
#include "empathy-accounts-plugin-widget.h"
@@ -38,9 +39,13 @@ widget_done_cb (EmpathyAccountsPluginWidget *widget,
static GtkWidget *
empathy_accounts_plugin_build_widget (ApPlugin *plugin)
{
+ AgAccount *account;
GtkWidget *widget;
- widget = empathy_accounts_plugin_widget_new (ap_plugin_get_account (plugin));
+ account = ap_plugin_get_account (plugin);
+ empathy_uoa_manager_set_default (ag_account_get_manager (account));
+
+ widget = empathy_accounts_plugin_widget_new (account);
g_signal_connect (widget, "done",
G_CALLBACK (widget_done_cb), plugin);