Commit 74a144f4 authored by John Brooks's avatar John Brooks

First compiling version of auth client ripped from empathy

parents
/*
* Copyright (C) 2010 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., 51 Franklin St, Fifth Floor,
* Boston, MA 02110-1301 USA
*
* Authors: Cosimo Cecchi <cosimo.cecchi@collabora.co.uk>
*/
#include <stdlib.h>
#include <glib.h>
#include <telepathy-glib/telepathy-glib.h>
#include "empathy-debug.h"
#include "empathy-utils.h"
#include <empathy-auth-factory.h>
#include <empathy-server-sasl-handler.h>
#include <empathy-server-tls-handler.h>
#if 0
#include <empathy-tls-verifier.h>
#define DEBUG_FLAG EMPATHY_DEBUG_TLS
#include <libempathy/empathy-debug.h>
#include <libempathy/empathy-utils.h>
#include <libempathy-gtk/empathy-bad-password-dialog.h>
#include <libempathy-gtk/empathy-password-dialog.h>
#include <libempathy-gtk/empathy-tls-dialog.h>
#include <libempathy-gtk/empathy-ui-utils.h>
#include "empathy-sanity-cleaning.h"
#include <gnutls/gnutls.h>
#include <extensions/extensions.h>
#endif
#define TIMEOUT 60
static gboolean use_timer = TRUE;
static guint timeout_id = 0;
static guint num_windows = 0;
static GMainLoop *main_loop = 0;
static gboolean
timeout_cb (gpointer p)
{
DEBUG ("Timeout reached; exiting...");
g_main_loop_quit(main_loop);
return FALSE;
}
static void
start_timer (void)
{
if (!use_timer)
return;
if (timeout_id != 0)
return;
DEBUG ("Start timer");
timeout_id = g_timeout_add_seconds (TIMEOUT, timeout_cb, NULL);
}
static void
stop_timer (void)
{
if (timeout_id == 0)
return;
DEBUG ("Stop timer");
g_source_remove (timeout_id);
timeout_id = 0;
}
#if 0
static void
tls_dialog_response_cb (GtkDialog *dialog,
gint response_id,
gpointer user_data)
{
TpTLSCertificate *certificate = NULL;
TpTLSCertificateRejectReason reason = 0;
GHashTable *details = NULL;
gboolean remember = FALSE;
EmpathyTLSVerifier *verifier = EMPATHY_TLS_VERIFIER (user_data);
g_object_get (tls_dialog,
"certificate", &certificate,
"reason", &reason,
"remember", &remember,
"details", &details,
NULL);
DEBUG ("Response %d (remember: %d)", response_id, remember);
gtk_widget_destroy (GTK_WIDGET (dialog));
if (response_id == GTK_RESPONSE_YES)
{
tp_tls_certificate_accept_async (certificate, NULL, NULL);
}
else
{
tp_asv_set_boolean (details, "user-requested", TRUE);
tp_tls_certificate_add_rejection (certificate, reason, NULL,
g_variant_new_parsed ("{ 'user-requested': <%b> }", TRUE));
tp_tls_certificate_reject_async (certificate, NULL, NULL);
}
if (remember)
empathy_tls_verifier_store_exception (verifier);
g_object_unref (certificate);
g_hash_table_unref (details);
/* restart the timeout */
num_windows--;
if (num_windows > 0)
return;
start_timer ();
}
#endif
#if 0
static void
verifier_verify_cb (GObject *source,
GAsyncResult *result,
gpointer user_data)
{
TpTLSCertificateRejectReason reason;
GError *error = NULL;
TpTLSCertificate *certificate = NULL;
GHashTable *details = NULL;
gchar *hostname = NULL;
g_object_get (source,
"certificate", &certificate,
NULL);
empathy_tls_verifier_verify_finish (EMPATHY_TLS_VERIFIER (source),
result, &reason, &details, &error);
if (error != NULL)
{
DEBUG ("Error: %s", error->message);
g_error_free (error);
}
else
{
tp_tls_certificate_accept_async (certificate, NULL, NULL);
}
g_free (hostname);
g_object_unref (certificate);
}
#endif
#if 0
static void
auth_factory_new_tls_handler_cb (EmpathyAuthFactory *factory,
EmpathyServerTLSHandler *handler,
gpointer user_data)
{
TpTLSCertificate *certificate = NULL;
gchar *hostname = NULL;
gchar **reference_identities = NULL;
EmpathyTLSVerifier *verifier;
DEBUG ("New TLS server handler received from the factory");
g_object_get (handler,
"certificate", &certificate,
"hostname", &hostname,
"reference-identities", &reference_identities,
NULL);
verifier = empathy_tls_verifier_new (certificate, hostname,
(const gchar **) reference_identities);
empathy_tls_verifier_verify_async (verifier,
verifier_verify_cb, NULL);
g_object_unref (verifier);
g_object_unref (certificate);
g_free (hostname);
g_strfreev (reference_identities);
}
#endif
static void
auth_factory_new_sasl_handler_cb (EmpathyAuthFactory *factory,
EmpathyServerSASLHandler *handler,
gpointer user_data)
{
DEBUG ("New SASL server handler received from the factory");
/* If the handler has the password it will deal with it itself. */
if (!empathy_server_sasl_handler_has_password (handler))
{
DEBUG ("SASL handler doesn't have a password, prompt for one");
}
}
#if 0
static void
retry_account_cb (GtkWidget *dialog,
TpAccount *account,
const gchar *password,
EmpathyAuthFactory *factory)
{
DEBUG ("Try reconnecting to %s", tp_account_get_path_suffix (account));
empathy_auth_factory_save_retry_password (factory, account, password);
tp_account_reconnect_async (account, NULL, NULL);
}
#endif
static void
auth_factory_auth_passsword_failed (EmpathyAuthFactory *factory,
TpAccount *account,
const gchar *password,
gpointer user_data)
{
DEBUG ("Authentication on %s failed, popup password dialog",
tp_account_get_path_suffix (account));
}
static void
sanity_cb (GObject *source,
GAsyncResult *result,
gpointer user_data)
{
start_timer ();
}
int
main (int argc,
char **argv)
{
GOptionContext *context;
GError *error = NULL;
EmpathyAuthFactory *factory;
TpDebugSender *debug_sender;
TpSimpleClientFactory *tp_factory;
TpDBusDaemon *dbus;
//gnutls_global_init ();
g_type_init();
main_loop = g_main_loop_new(NULL, FALSE);
#ifdef ENABLE_DEBUG
/* Set up debug sender */
debug_sender = tp_debug_sender_dup ();
g_log_set_default_handler (tp_debug_sender_log_handler, G_LOG_DOMAIN);
#endif
dbus = tp_dbus_daemon_dup (NULL);
tp_factory = tp_simple_client_factory_new (dbus);
tp_simple_client_factory_add_account_features_varargs (tp_factory,
TP_ACCOUNT_FEATURE_STORAGE,
0);
factory = empathy_auth_factory_new (tp_factory);
g_object_unref (tp_factory);
g_object_unref (dbus);
//g_signal_connect (factory, "new-server-tls-handler",
// G_CALLBACK (auth_factory_new_tls_handler_cb), NULL);
g_signal_connect (factory, "new-server-sasl-handler",
G_CALLBACK (auth_factory_new_sasl_handler_cb), NULL);
g_signal_connect (factory, "auth-password-failed",
G_CALLBACK (auth_factory_auth_passsword_failed), NULL);
if (!empathy_auth_factory_register (factory, &error))
{
g_critical ("Failed to register the auth factory: %s\n", error->message);
g_error_free (error);
g_object_unref (factory);
return EXIT_FAILURE;
}
DEBUG ("Empathy auth client started.");
if (g_getenv ("EMPATHY_PERSIST") != NULL)
{
DEBUG ("Timed-exit disabled");
use_timer = FALSE;
}
g_main_loop_run(main_loop);
g_object_unref (factory);
g_object_unref (debug_sender);
return EXIT_SUCCESS;
}
This diff is collapsed.
/*
* empathy-auth-factory.h - Header for EmpathyAuthFactory
* Copyright (C) 2010 Collabora Ltd.
* @author Cosimo Cecchi <cosimo.cecchi@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_AUTH_FACTORY_H__
#define __EMPATHY_AUTH_FACTORY_H__
#include <glib-object.h>
#include <telepathy-glib/telepathy-glib.h>
G_BEGIN_DECLS
typedef struct _EmpathyAuthFactory EmpathyAuthFactory;
typedef struct _EmpathyAuthFactoryClass EmpathyAuthFactoryClass;
typedef struct _EmpathyAuthFactoryPriv EmpathyAuthFactoryPriv;
struct _EmpathyAuthFactoryClass {
TpBaseClientClass parent_class;
};
struct _EmpathyAuthFactory {
TpBaseClient parent;
EmpathyAuthFactoryPriv *priv;
};
GType empathy_auth_factory_get_type (void);
/* TYPE MACROS */
#define EMPATHY_TYPE_AUTH_FACTORY \
(empathy_auth_factory_get_type ())
#define EMPATHY_AUTH_FACTORY(obj) \
(G_TYPE_CHECK_INSTANCE_CAST((obj), EMPATHY_TYPE_AUTH_FACTORY, \
EmpathyAuthFactory))
#define EMPATHY_AUTH_FACTORY_CLASS(klass) \
(G_TYPE_CHECK_CLASS_CAST((klass), EMPATHY_TYPE_AUTH_FACTORY, \
EmpathyAuthFactoryClass))
#define EMPATHY_IS_AUTH_FACTORY(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE((obj), EMPATHY_TYPE_AUTH_FACTORY))
#define EMPATHY_IS_AUTH_FACTORY_CLASS(klass) \
(G_TYPE_CHECK_CLASS_TYPE((klass), EMPATHY_TYPE_AUTH_FACTORY))
#define EMPATHY_AUTH_FACTORY_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_CLASS ((obj), EMPATHY_TYPE_AUTH_FACTORY, \
EmpathyAuthFactoryClass))
EmpathyAuthFactory * empathy_auth_factory_new (TpSimpleClientFactory *factory);
gboolean empathy_auth_factory_register (EmpathyAuthFactory *self,
GError **error);
void empathy_auth_factory_save_retry_password (EmpathyAuthFactory *self,
TpAccount *account,
const gchar *password);
G_END_DECLS
#endif /* #ifndef __EMPATHY_AUTH_FACTORY_H__*/
#define DEBUG g_debug
This diff is collapsed.
/*
* Copyright (C) 2010 Collabora Ltd.
*
* 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_KEYRING_H__
#define __EMPATHY_KEYRING_H__
#include <gio/gio.h>
#include <telepathy-glib/telepathy-glib.h>
G_BEGIN_DECLS
gboolean empathy_keyring_is_available (void);
void empathy_keyring_get_account_password_async (TpAccount *account,
GAsyncReadyCallback callback, gpointer user_data);
const gchar * empathy_keyring_get_account_password_finish (TpAccount *account,
GAsyncResult *result, GError **error);
void empathy_keyring_get_room_password_async (TpAccount *account,
const gchar *id,
GAsyncReadyCallback callback, gpointer user_data);
const gchar * empathy_keyring_get_room_password_finish (TpAccount *account,
GAsyncResult *result, GError **error);
void empathy_keyring_set_account_password_async (TpAccount *account,
const gchar *password, gboolean remember, GAsyncReadyCallback callback,
gpointer user_data);
gboolean empathy_keyring_set_account_password_finish (TpAccount *account,
GAsyncResult *result, GError **error);
void empathy_keyring_set_room_password_async (TpAccount *account,
const gchar *id, const gchar *password, GAsyncReadyCallback callback,
gpointer user_data);
gboolean empathy_keyring_set_room_password_finish (TpAccount *account,
GAsyncResult *result, GError **error);
void empathy_keyring_delete_account_password_async (TpAccount *account,
GAsyncReadyCallback callback, gpointer user_data);
gboolean empathy_keyring_delete_account_password_finish (TpAccount *account,
GAsyncResult *result, GError **error);
G_END_DECLS
#endif /* __EMPATHY_KEYRING_H__ */
This diff is collapsed.
/*
* empathy-sasl-mechanisms.h - Header for SASL authentication mechanisms
* 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_SASL_MECHANISMS_H__
#define __EMPATHY_SASL_MECHANISMS_H__
#include <telepathy-glib/telepathy-glib.h>
G_BEGIN_DECLS
typedef enum
{
EMPATHY_SASL_MECHANISM_UNSUPPORTED,
EMPATHY_SASL_MECHANISM_FACEBOOK,
EMPATHY_SASL_MECHANISM_WLM,
EMPATHY_SASL_MECHANISM_GOOGLE,
EMPATHY_SASL_MECHANISM_PASSWORD,
} EmpathySaslMechanism;
void empathy_sasl_auth_facebook_async (TpChannel *channel,
const gchar *client_id,
const gchar *access_token,
GAsyncReadyCallback callback,
gpointer user_data);
void empathy_sasl_auth_wlm_async (TpChannel *channel,
const gchar *access_token,
GAsyncReadyCallback callback,
gpointer user_data);
void empathy_sasl_auth_google_async (TpChannel *channel,
const gchar *username,
const gchar *access_token,
GAsyncReadyCallback callback,
gpointer user_data);
void empathy_sasl_auth_password_async (TpChannel *channel,
const gchar *password,
GAsyncReadyCallback callback,
gpointer user_data);
gboolean empathy_sasl_auth_finish (TpChannel *channel,
GAsyncResult *result,
GError **error);
gboolean empathy_sasl_channel_supports_mechanism (TpChannel *channel,
const gchar *mechanism);
EmpathySaslMechanism empathy_sasl_channel_select_mechanism (TpChannel *channel);
G_END_DECLS
#endif /* #ifndef __EMPATHY_SASL_MECHANISMS_H__*/
This diff is collapsed.
/*
* empathy-server-sasl-handler.h - Header for EmpathyServerSASLHandler
* Copyright (C) 2010 Collabora Ltd.
*
* 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_SERVER_SASL_HANDLER_H__
#define __EMPATHY_SERVER_SASL_HANDLER_H__
#include <glib-object.h>
#include <gio/gio.h>
#include <telepathy-glib/telepathy-glib.h>
G_BEGIN_DECLS
typedef struct _EmpathyServerSASLHandler EmpathyServerSASLHandler;
typedef struct _EmpathyServerSASLHandlerClass EmpathyServerSASLHandlerClass;
struct _EmpathyServerSASLHandlerClass {
GObjectClass parent_class;
};
struct _EmpathyServerSASLHandler {
GObject parent;
gpointer priv;
};
GType empathy_server_sasl_handler_get_type (void);
#define EMPATHY_TYPE_SERVER_SASL_HANDLER \
(empathy_server_sasl_handler_get_type ())
#define EMPATHY_SERVER_SASL_HANDLER(obj) \
(G_TYPE_CHECK_INSTANCE_CAST((obj), EMPATHY_TYPE_SERVER_SASL_HANDLER, \
EmpathyServerSASLHandler))
#define EMPATHY_SERVER_SASL_HANDLER_CLASS(klass) \
(G_TYPE_CHECK_CLASS_CAST((klass), EMPATHY_TYPE_SERVER_SASL_HANDLER, \
EmpathyServerSASLHandlerClass))
#define EMPATHY_IS_SERVER_SASL_HANDLER(obj) \
(G_TYPE_CHECK_INSTANCE_TYPE((obj), EMPATHY_TYPE_SERVER_SASL_HANDLER))
#define EMPATHY_IS_SERVER_SASL_HANDLER_CLASS(klass) \
(G_TYPE_CHECK_CLASS_TYPE((klass), EMPATHY_TYPE_SERVER_SASL_HANDLER))
#define EMPATHY_SERVER_SASL_HANDLER_GET_CLASS(obj) \
(G_TYPE_INSTANCE_GET_CLASS ((obj), EMPATHY_TYPE_SERVER_SASL_HANDLER, \
EmpathyServerSASLHandlerClass))
void empathy_server_sasl_handler_new_async (
TpAccount *account, TpChannel *channel,
GAsyncReadyCallback callback, gpointer user_data);
EmpathyServerSASLHandler * empathy_server_sasl_handler_new_finish (
GAsyncResult *result, GError **error);
void empathy_server_sasl_handler_provide_password (
EmpathyServerSASLHandler *handler, const gchar *password,
gboolean remember);
void empathy_server_sasl_handler_cancel (EmpathyServerSASLHandler *handler);
TpAccount * empathy_server_sasl_handler_get_account (
EmpathyServerSASLHandler *handler);
TpChannel * empathy_server_sasl_handler_get_channel (
EmpathyServerSASLHandler *handler);
gboolean empathy_server_sasl_handler_has_password (
EmpathyServerSASLHandler *handler);
gboolean empathy_server_sasl_handler_can_save_response_somewhere (
EmpathyServerSASLHandler *self);
G_END_DECLS
#endif /* #ifndef __EMPATHY_SERVER_SASL_HANDLER_H__*/
/*
* empathy-server-tls-handler.c - Source for EmpathyServerTLSHandler
* Copyright (C) 2010 Collabora Ltd.
* @author Cosimo Cecchi <cosimo.cecchi@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 "empathy-server-tls-handler.h"
#include "empathy-utils.h"
#include "empathy-debug.h"
static void async_initable_iface_init (GAsyncInitableIface *iface);
enum {
PROP_CHANNEL = 1,
PROP_TLS_CERTIFICATE,
PROP_HOSTNAME,
PROP_REFERENCE_IDENTITIES,
LAST_PROPERTY,
};
typedef struct {
TpChannel *channel;
TpTLSCertificate *certificate;
gchar *hostname;
gchar **reference_identities;
GSimpleAsyncResult *async_init_res;
} EmpathyServerTLSHandlerPriv;
G_DEFINE_TYPE_WITH_CODE (EmpathyServerTLSHandler, empathy_server_tls_handler,
G_TYPE_OBJECT,
G_IMPLEMENT_INTERFACE (G_TYPE_ASYNC_INITABLE, async_initable_iface_init));
#define GET_PRIV(obj) EMPATHY_GET_PRIV (obj, EmpathyServerTLSHandler);
static void
tls_certificate_prepared_cb (GObject *source,
GAsyncResult *result,
gpointer user_data)
{
TpTLSCertificate *certificate = TP_TLS_CERTIFICATE (source);
EmpathyServerTLSHandler *self = user_data;
GError *error = NULL;
EmpathyServerTLSHandlerPriv *priv = GET_PRIV (self);
if (!tp_proxy_prepare_finish (certificate, result, &error))
{
g_simple_async_result_set_from_error (priv->async_init_res, error);
g_error_free (error);
}
g_simple_async_result_complete_in_idle (priv->async_init_res);
tp_clear_object (&priv->async_init_res);
}
static gboolean
tls_handler_init_finish (GAsyncInitable *initable,
GAsyncResult *res,
GError **error)
{
gboolean retval = TRUE;
if (g_simple_async_result_propagate_error (G_SIMPLE_ASYNC_RESULT (res),
error))
retval = FALSE;
return retval;
}
static void
tls_handler_init_async (GAsyncInitable *initable,
gint io_priority,
GCancellable *cancellable,
GAsyncReadyCallback callback,
gpointer user_data)
{
GVariant *properties;
const gchar *cert_object_path;
const gchar *bus_name;
GError *error = NULL;
GQuark features[] = { TP_TLS_CERTIFICATE_FEATURE_CORE, 0 };
/*
* Used when channel doesn't implement ReferenceIdentities. A GStrv
* with [0] the hostname, and [1] a NULL terminator.
*/
gchar *default_identities[2];
EmpathyServerTLSHandler *self = EMPATHY_SERVER_TLS_HANDLER (initable);
EmpathyServerTLSHandlerPriv *priv = GET_PRIV (self);
g_assert (priv->channel != NULL);
priv->async_init_res = g_simple_async_result_new (G_OBJECT (self),
callback, user_data, empathy_server_tls_handler_new_async);
properties = tp_channel_dup_immutable_properties (priv->channel);
g_variant_lookup (properties,
TP_PROP_CHANNEL_TYPE_SERVER_TLS_CONNECTION_HOSTNAME,
"s", &priv->hostname);
DEBUG ("Received hostname: %s", priv->hostname);
g_variant_lookup (properties,
TP_PROP_CHANNEL_TYPE_SERVER_TLS_CONNECTION_REFERENCE_IDENTITIES,
"^as", &priv->reference_identities);
/*
* If the channel doesn't implement the ReferenceIdentities parameter
* then fallback to the hostname.
*/
if (priv->reference_identities == NULL)
{
default_identities[0] = (gchar *) priv->hostname;
default_identities[1] = NULL;