libpurple/purplenoopcredentialprovider.c

Thu, 25 Aug 2022 23:25:12 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Thu, 25 Aug 2022 23:25:12 -0500
branch
gtk4
changeset 41598
2b34cd990c16
parent 40790
e92d5c060155
child 41960
c8a4853205e3
permissions
-rw-r--r--

Replace the style-updated signal with GtkIconTheme:changed

Testing Done:
Ran and make sure the `GWarning` went away.

Reviewed at https://reviews.imfreedom.org/r/1653/

/*
 * Purple - Internet Messaging Library
 * Copyright (C) Pidgin Developers <devel@pidgin.im>
 *
 * 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 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 <https://www.gnu.org/licenses/>.
 */

#include <glib/gi18n-lib.h>

#include "purplenoopcredentialprovider.h"

#include "purplecredentialmanager.h"

struct _PurpleNoopCredentialProvider {
	PurpleCredentialProvider parent;
};

G_DEFINE_TYPE(PurpleNoopCredentialProvider, purple_noop_credential_provider,
              PURPLE_TYPE_CREDENTIAL_PROVIDER)

/******************************************************************************
 * PurpleCredentialProvider Implementation
 *****************************************************************************/
static void
purple_noop_credential_provider_read_password_async(PurpleCredentialProvider *provider,
                                                    PurpleAccount *account,
                                                    GCancellable *cancellable,
                                                    GAsyncReadyCallback callback,
                                                    gpointer data)
{
	GTask *task = g_task_new(G_OBJECT(provider), cancellable, callback, data);

	g_task_return_new_error(task, PURPLE_CREDENTIAL_MANAGER_DOMAIN, 0,
	                        _("provider does not store passwords"));

	g_object_unref(G_OBJECT(task));
}

static gchar *
purple_noop_credential_provider_read_password_finish(PurpleCredentialProvider *provider,
                                                     GAsyncResult *result,
                                                     GError **error)
{
	return g_task_propagate_pointer(G_TASK(result), error);
}

static void
purple_noop_credential_provider_write_password_async(PurpleCredentialProvider *provider,
                                                     PurpleAccount *account,
                                                     const gchar *password,
                                                     GCancellable *cancellable,
                                                     GAsyncReadyCallback callback,
                                                     gpointer data)
{
	GTask *task = g_task_new(G_OBJECT(provider), cancellable, callback, data);

	g_task_return_new_error(task, PURPLE_CREDENTIAL_MANAGER_DOMAIN, 0,
	                        _("provider does not store passwords"));

	g_object_unref(G_OBJECT(task));
}

static gboolean
purple_noop_credential_provider_write_password_finish(PurpleCredentialProvider *provider,
                                                      GAsyncResult *result,
                                                      GError **error)
{
	return g_task_propagate_boolean(G_TASK(result), error);
}

/******************************************************************************
 * GObject Implementation
 *****************************************************************************/
static void
purple_noop_credential_provider_init(PurpleNoopCredentialProvider *provider) {
}

static void
purple_noop_credential_provider_class_init(PurpleNoopCredentialProviderClass *klass)
{
	PurpleCredentialProviderClass *provider_class = NULL;

	provider_class = PURPLE_CREDENTIAL_PROVIDER_CLASS(klass);
	provider_class->read_password_async =
		purple_noop_credential_provider_read_password_async;
	provider_class->read_password_finish =
		purple_noop_credential_provider_read_password_finish;
	provider_class->write_password_async =
		purple_noop_credential_provider_write_password_async;
	provider_class->write_password_finish =
		purple_noop_credential_provider_write_password_finish;
}

/******************************************************************************
 * Public API
 *****************************************************************************/
PurpleCredentialProvider *
purple_noop_credential_provider_new(void) {
	return PURPLE_CREDENTIAL_PROVIDER(g_object_new(
		PURPLE_TYPE_NOOP_CREDENTIAL_PROVIDER,
		"id", "noop-provider",
		"name", _("None"),
		"description", _("Passwords will not be saved."),
		NULL
	));
}

mercurial