pidgin/pidgin

Remove the private data from PurplePresence
default tip
9 hours ago, Gary Kramlich
939814cb9972
Remove the private data from PurplePresence

Testing Done:
Ran the turtles.

Reviewed at https://reviews.imfreedom.org/r/3149/
/*
* Purple - Internet Messaging Library
* Copyright (C) Pidgin Developers <devel@pidgin.im>
*
* Purple is the legal property of its developers, whose names are too numerous
* to list here. Please refer to the COPYRIGHT file distributed with this
* source distribution.
*
* This library 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 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 General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License along with
* this library; if not, see <https://www.gnu.org/licenses/>.
*/
#include "purpleprotocolcontacts.h"
#include "util.h"
/******************************************************************************
* GInterface Implementation
*****************************************************************************/
G_DEFINE_INTERFACE(PurpleProtocolContacts, purple_protocol_contacts,
PURPLE_TYPE_PROTOCOL)
static void
purple_protocol_contacts_default_init(G_GNUC_UNUSED PurpleProtocolContactsInterface *iface)
{
}
/******************************************************************************
* Public API
*****************************************************************************/
void
purple_protocol_contacts_search_async(PurpleProtocolContacts *protocol_contacts,
PurpleAccount *account,
const char *text,
GCancellable *cancellable,
GAsyncReadyCallback callback,
gpointer data)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts));
g_return_if_fail(PURPLE_IS_ACCOUNT(account));
g_return_if_fail(!purple_strempty(text));
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->search_async != NULL) {
iface->search_async(protocol_contacts, account, text, cancellable,
callback, data);
} else {
g_warning("%s does not implement search_async",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
}
GListModel *
purple_protocol_contacts_search_finish(PurpleProtocolContacts *protocol_contacts,
GAsyncResult *result,
GError **error)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->search_finish != NULL) {
GListModel *ret = NULL;
ret = iface->search_finish(protocol_contacts, result, error);
if(G_IS_LIST_MODEL(ret)) {
GType type = G_TYPE_INVALID;
type = g_list_model_get_item_type(G_LIST_MODEL(ret));
if(g_type_is_a(type, PURPLE_TYPE_CONTACT_INFO)) {
return ret;
}
/* The GListModel we got back doesn't have an item type that is
* PurpleContactInfo or a subclass of it.
*/
g_clear_object(&ret);
g_set_error(error, PURPLE_PROTOCOL_CONTACTS_DOMAIN, 0,
"%s returned a list of type %s which is not "
"PurpleContactInfo or a subclass of",
G_OBJECT_TYPE_NAME(protocol_contacts),
g_type_name(type));
}
} else {
g_warning("%s does not implement search_finish",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
return NULL;
}
void
purple_protocol_contacts_get_profile_async(PurpleProtocolContacts *protocol_contacts,
PurpleContactInfo *info,
GCancellable *cancellable,
GAsyncReadyCallback callback,
gpointer data)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts));
g_return_if_fail(PURPLE_IS_CONTACT_INFO(info));
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_profile_async != NULL) {
iface->get_profile_async(protocol_contacts, info, cancellable,
callback, data);
} else {
g_warning("%s does not implement get_profile_async",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
}
char *
purple_protocol_contacts_get_profile_finish(PurpleProtocolContacts *protocol_contacts,
GAsyncResult *result,
GError **error)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_profile_finish != NULL) {
return iface->get_profile_finish(protocol_contacts, result, error);
} else {
g_warning("%s does not implement get_profile_finish",
G_OBJECT_TYPE_NAME(protocol_contacts));
}
return NULL;
}
GActionGroup *
purple_protocol_contacts_get_actions(PurpleProtocolContacts *protocol_contacts,
PurpleContactInfo *info)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
g_return_val_if_fail(PURPLE_IS_CONTACT_INFO(info), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_actions != NULL) {
return iface->get_actions(protocol_contacts, info);
}
return NULL;
}
GMenuModel *
purple_protocol_contacts_get_menu(PurpleProtocolContacts *protocol_contacts,
PurpleContactInfo *info)
{
PurpleProtocolContactsInterface *iface = NULL;
g_return_val_if_fail(PURPLE_IS_PROTOCOL_CONTACTS(protocol_contacts), NULL);
g_return_val_if_fail(PURPLE_IS_CONTACT_INFO(info), NULL);
iface = PURPLE_PROTOCOL_CONTACTS_GET_IFACE(protocol_contacts);
if(iface != NULL && iface->get_menu != NULL) {
return iface->get_menu(protocol_contacts, info);
}
return NULL;
}