finch/gntrequest.h

Mon, 22 Aug 2022 22:05:55 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Mon, 22 Aug 2022 22:05:55 -0500
changeset 41514
a96768bacb59
parent 41123
089c8a3a9ff4
child 42128
118067ca0367
permissions
-rw-r--r--

Create PurpleAuthorizationRequest and use it for notifications.

This replaces the old internal representation of authorization requests as well
as the UI's implementation of their own objects. Everything is now controlled
via PurpleAuthorizationRequest and the UI's display the notification for
interaction.

Testing Done:
Verified the notification and actions work in both finch and pidgin.

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

/*
 * finch
 *
 * Finch 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 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 Street, Fifth Floor, Boston, MA  02111-1301  USA
 */

#if !defined(FINCH_GLOBAL_HEADER_INSIDE) && !defined(FINCH_COMPILATION)
# error "only <finch.h> may be included directly"
#endif

#ifndef FINCH_REQUEST_H
#define FINCH_REQUEST_H

#include <purple.h>

#include "gnt.h"

/**********************************************************************
 * GNT Request API
 **********************************************************************/

/**
 * finch_request_get_ui_ops:
 *
 * Get the ui-functions.
 *
 * Returns: The PurpleRequestUiOps structure populated with the appropriate functions.
 */
PurpleRequestUiOps *finch_request_get_ui_ops(void);

/**
 * finch_request_init:
 *
 * Perform necessary initializations.
 */
void finch_request_init(void);

/**
 * finch_request_uninit:
 *
 * Perform necessary uninitializations.
 */
void finch_request_uninit(void);

/**
 * finch_request_save_in_prefs:
 * @data: No longer used, set to %NULL.
 * @fields: The #PurpleRequestFields to save.
 *
 * Save the request fields in preferences where the id attribute of each field is the
 * id of a preference.
 */
void finch_request_save_in_prefs(gpointer data, PurpleRequestFields *fields);

/**
 * finch_request_field_get_widget:
 * @field:   The request field.
 *
 * Create a widget field for a request-field.
 *
 * Returns: (transfer full): A GntWidget for the request field.
 */
GntWidget *finch_request_field_get_widget(PurpleRequestField *field);

#endif /* FINCH_REQUEST_H */

mercurial