aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXavier Claessens <xavier.claessens@collabora.co.uk>2012-08-23 20:57:52 +0800
committerXavier Claessens <xavier.claessens@collabora.co.uk>2012-08-27 21:47:21 +0800
commitfb84a9d544c27f11c3c91efdad8adc4096471a79 (patch)
tree768766e918811db17d508f89c61ffb0bcb02bc96
parent9ce89862ae5bead69519f3238794ffbf3988dcf9 (diff)
downloadgsoc2013-empathy-fb84a9d544c27f11c3c91efdad8adc4096471a79.tar
gsoc2013-empathy-fb84a9d544c27f11c3c91efdad8adc4096471a79.tar.gz
gsoc2013-empathy-fb84a9d544c27f11c3c91efdad8adc4096471a79.tar.bz2
gsoc2013-empathy-fb84a9d544c27f11c3c91efdad8adc4096471a79.tar.lz
gsoc2013-empathy-fb84a9d544c27f11c3c91efdad8adc4096471a79.tar.xz
gsoc2013-empathy-fb84a9d544c27f11c3c91efdad8adc4096471a79.tar.zst
gsoc2013-empathy-fb84a9d544c27f11c3c91efdad8adc4096471a79.zip
UOA auth: Move more code into auth_context_new()
https://bugzilla.gnome.org/show_bug.cgi?id=680776
-rw-r--r--libempathy/empathy-uoa-auth-handler.c72
1 files changed, 37 insertions, 35 deletions
diff --git a/libempathy/empathy-uoa-auth-handler.c b/libempathy/empathy-uoa-auth-handler.c
index f88acf120..ee377349d 100644
--- a/libempathy/empathy-uoa-auth-handler.c
+++ b/libempathy/empathy-uoa-auth-handler.c
@@ -82,37 +82,52 @@ typedef struct
{
TpChannel *channel;
AgAuthData *auth_data;
- SignonAuthSession *session;
SignonIdentity *identity;
+ SignonAuthSession *session;
gchar *username;
} AuthContext;
static AuthContext *
auth_context_new (TpChannel *channel,
- AgAuthData *auth_data,
- SignonAuthSession *session,
- SignonIdentity *identity)
+ AgAccountService *service)
{
AuthContext *ctx;
+ guint cred_id;
ctx = g_slice_new0 (AuthContext);
ctx->channel = g_object_ref (channel);
- ctx->auth_data = ag_auth_data_ref (auth_data);
- ctx->session = g_object_ref (session);
- ctx->identity = g_object_ref (identity);
+ ctx->auth_data = ag_account_service_get_auth_data (service);
+ if (ctx->auth_data == NULL)
+ goto out;
+
+ cred_id = ag_auth_data_get_credentials_id (ctx->auth_data);
+ if (cred_id == 0)
+ goto out;
+
+ ctx->identity = signon_identity_new_from_db (cred_id);
+ if (ctx->identity == NULL)
+ goto out;
+
+ ctx->session = signon_identity_create_session (ctx->identity,
+ ag_auth_data_get_method (ctx->auth_data), NULL);
+ if (ctx->session == NULL)
+ goto out;
+
+out:
return ctx;
}
static void
auth_context_free (AuthContext *ctx)
{
- g_object_unref (ctx->channel);
- ag_auth_data_unref (ctx->auth_data);
- g_object_unref (ctx->session);
- g_object_unref (ctx->identity);
+ g_clear_object (&ctx->channel);
+ tp_clear_pointer (&ctx->auth_data, ag_auth_data_unref);
+ g_clear_object (&ctx->session);
+ g_clear_object (&ctx->identity);
g_free (ctx->username);
+
g_slice_free (AuthContext, ctx);
}
@@ -243,11 +258,7 @@ empathy_uoa_auth_handler_start (EmpathyUoaAuthHandler *self,
AgAccount *account;
GList *l = NULL;
AgAccountService *service;
- AgAuthData *auth_data;
- guint cred_id;
- SignonIdentity *identity;
- SignonAuthSession *session;
- GError *error = NULL;
+ AuthContext *ctx;
g_return_if_fail (TP_IS_CHANNEL (channel));
g_return_if_fail (TP_IS_ACCOUNT (tp_account));
@@ -276,29 +287,20 @@ empathy_uoa_auth_handler_start (EmpathyUoaAuthHandler *self,
ag_service_list_free (l);
g_object_unref (account);
- auth_data = ag_account_service_get_auth_data (service);
- cred_id = ag_auth_data_get_credentials_id (auth_data);
- identity = signon_identity_new_from_db (cred_id);
- session = signon_identity_create_session (identity,
- ag_auth_data_get_method (auth_data),
- &error);
- if (session == NULL)
+ ctx = auth_context_new (channel, service);
+ if (ctx->session == NULL)
{
- DEBUG ("Error creating a SignonAuthSession: %s", error->message);
- tp_channel_close_async (channel, NULL, NULL);
- goto cleanup;
+ DEBUG ("Couldn't create a signon session");
+ auth_context_done (ctx);
+ }
+ else
+ {
+ /* All is fine! Query UOA for more info */
+ signon_identity_query_info (ctx->identity,
+ identity_query_info_cb, ctx);
}
- /* Query UOA for more info */
- signon_identity_query_info (identity,
- identity_query_info_cb,
- auth_context_new (channel, auth_data, session, identity));
-
-cleanup:
- ag_auth_data_unref (auth_data);
g_object_unref (service);
- g_object_unref (identity);
- g_object_unref (session);
}
gboolean