/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */ /* * Copyright (C) 2011 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, see * . * * In addition, when the library is used with OpenSSL, a special * exception applies. Refer to the LICENSE_EXCEPTION file for details. * * Author: Stef Walter */ #include "config.h" #include #include #include "mock-interaction.h" struct _MockInteraction { GTlsInteraction parent_instance; gchar *static_password; GTlsCertificate *static_certificate; GError *static_error; }; G_DEFINE_TYPE (MockInteraction, mock_interaction, G_TYPE_TLS_INTERACTION); static void mock_interaction_ask_password_async (GTlsInteraction *interaction, GTlsPassword *password, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data) { MockInteraction *self = MOCK_INTERACTION (interaction); GTask *task; task = g_task_new (interaction, cancellable, callback, user_data); if (self->static_error) g_task_return_error (task, g_error_copy (self->static_error)); else g_tls_password_set_value (password, (const guchar *)self->static_password, -1); g_task_return_boolean (task, TRUE); g_object_unref (task); } static GTlsInteractionResult mock_interaction_ask_password_finish (GTlsInteraction *interaction, GAsyncResult *result, GError **error) { g_return_val_if_fail (g_task_is_valid (result, interaction), G_TLS_INTERACTION_UNHANDLED); if (g_task_had_error (G_TASK (result))) { g_task_propagate_boolean (G_TASK (result), error); return G_TLS_INTERACTION_FAILED; } else return G_TLS_INTERACTION_HANDLED; } static GTlsInteractionResult mock_interaction_ask_password (GTlsInteraction *interaction, GTlsPassword *password, GCancellable *cancellable, GError **error) { MockInteraction *self = MOCK_INTERACTION (interaction); if (g_cancellable_set_error_if_cancelled (cancellable, error)) return G_TLS_INTERACTION_FAILED; if (self->static_error) { g_propagate_error (error, g_error_copy (self->static_error)); return G_TLS_INTERACTION_FAILED; } else { g_tls_password_set_value (password, (const guchar *)self->static_password, -1); return G_TLS_INTERACTION_HANDLED; } } static void mock_interaction_request_certificate_async (GTlsInteraction *interaction, GTlsConnection *connection, GTlsCertificateRequestFlags flags, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data) { MockInteraction *self = MOCK_INTERACTION (interaction); GTask *task; task = g_task_new (interaction, cancellable, callback, user_data); if (self->static_error) g_task_return_error (task, g_error_copy (self->static_error)); else { g_tls_connection_set_certificate (connection, self->static_certificate); g_task_return_boolean (task, TRUE); } g_object_unref (task); } static GTlsInteractionResult mock_interaction_request_certificate_finish (GTlsInteraction *interaction, GAsyncResult *result, GError **error) { g_return_val_if_fail (g_task_is_valid (result, interaction), G_TLS_INTERACTION_UNHANDLED); if (!g_task_propagate_boolean (G_TASK (result), error)) return G_TLS_INTERACTION_FAILED; else return G_TLS_INTERACTION_HANDLED; } static GTlsInteractionResult mock_interaction_request_certificate (GTlsInteraction *interaction, GTlsConnection *connection, GTlsCertificateRequestFlags flags, GCancellable *cancellable, GError **error) { MockInteraction *self = MOCK_INTERACTION (interaction); if (g_cancellable_set_error_if_cancelled (cancellable, error)) return G_TLS_INTERACTION_FAILED; if (self->static_error) { g_propagate_error (error, g_error_copy (self->static_error)); return G_TLS_INTERACTION_FAILED; } else { g_tls_connection_set_certificate (connection, self->static_certificate); return G_TLS_INTERACTION_HANDLED; } } static void mock_interaction_init (MockInteraction *self) { } static void mock_interaction_finalize (GObject *object) { MockInteraction *self = MOCK_INTERACTION (object); g_free (self->static_password); g_clear_object (&self->static_certificate); g_clear_error (&self->static_error); G_OBJECT_CLASS (mock_interaction_parent_class)->finalize (object); } static void mock_interaction_class_init (MockInteractionClass *klass) { GObjectClass *object_class = G_OBJECT_CLASS (klass); GTlsInteractionClass *interaction_class = G_TLS_INTERACTION_CLASS (klass); object_class->finalize = mock_interaction_finalize; interaction_class->ask_password = mock_interaction_ask_password; interaction_class->ask_password_async = mock_interaction_ask_password_async; interaction_class->ask_password_finish = mock_interaction_ask_password_finish; interaction_class->request_certificate = mock_interaction_request_certificate; interaction_class->request_certificate_async = mock_interaction_request_certificate_async; interaction_class->request_certificate_finish = mock_interaction_request_certificate_finish; } GTlsInteraction * mock_interaction_new_static_password (const gchar *password) { MockInteraction *self; self = g_object_new (MOCK_TYPE_INTERACTION, NULL); self->static_password = g_strdup (password); return G_TLS_INTERACTION (self); } GTlsInteraction * mock_interaction_new_static_certificate (GTlsCertificate *cert) { MockInteraction *self; self = g_object_new (MOCK_TYPE_INTERACTION, NULL); self->static_certificate = cert ? g_object_ref (cert) : NULL; return G_TLS_INTERACTION (self); } GTlsInteraction * mock_interaction_new_static_error (GQuark domain, gint code, const gchar *message) { MockInteraction *self; self = g_object_new (MOCK_TYPE_INTERACTION, NULL); self->static_error = g_error_new (domain, code, "%s", message); return G_TLS_INTERACTION (self); }