libpurple/purpleproxyinfo.h

Mon, 30 Jun 2025 14:22:13 -0500

author
Gary Kramlich <grim@reaperworld.com>
date
Mon, 30 Jun 2025 14:22:13 -0500
changeset 43269
1523eab3b5a0
parent 43075
0639bc52668a
permissions
-rw-r--r--

Update the flatpak to gnome 48 and to the matching birb version

The birb version was missed here when it was updated.

Testing Done:
Built the flatpak with the instructions in the readme.

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

/*
 * 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/>.
 */

#if !defined(PURPLE_GLOBAL_HEADER_INSIDE) && !defined(PURPLE_COMPILATION)
# error "only <purple.h> may be included directly"
#endif

#ifndef PURPLE_PROXY_INFO_H
#define PURPLE_PROXY_INFO_H

#include <glib.h>
#include <glib-object.h>

#include "purpleversion.h"

/**
 * PurpleProxyType:
 * @PURPLE_PROXY_TYPE_USE_GLOBAL: Use the global proxy information.
 * @PURPLE_PROXY_TYPE_NONE:  No proxy.
 * @PURPLE_PROXY_TYPE_HTTP: HTTP proxy.
 * @PURPLE_PROXY_TYPE_SOCKS4: SOCKS 4 proxy.
 * @PURPLE_PROXY_TYPE_SOCKS5: SOCKS 5 proxy.
 * @PURPLE_PROXY_TYPE_USE_ENVVAR: Use environmental settings.
 * @PURPLE_PROXY_TYPE_TOR: Use a Tor proxy (SOCKS 5 really).
 *
 * A type of proxy connection.
 *
 * Since: 2.0
 */
typedef enum {
	PURPLE_PROXY_TYPE_USE_GLOBAL = -1,
	PURPLE_PROXY_TYPE_NONE = 0,
	PURPLE_PROXY_TYPE_HTTP,
	PURPLE_PROXY_TYPE_SOCKS4,
	PURPLE_PROXY_TYPE_SOCKS5,
	PURPLE_PROXY_TYPE_USE_ENVVAR,
	PURPLE_PROXY_TYPE_TOR
} PurpleProxyType;

G_BEGIN_DECLS

#define PURPLE_TYPE_PROXY_INFO (purple_proxy_info_get_type())

/**
 * PurpleProxyInfo:
 *
 * A representation of a proxy.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_3_0
G_DECLARE_FINAL_TYPE(PurpleProxyInfo, purple_proxy_info, PURPLE, PROXY_INFO,
                     GObject)

/**
 * purple_proxy_info_new:
 *
 * Creates a new proxy info instance.
 *
 * Returns: (transfer full): The new instance.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_ALL
PurpleProxyInfo *purple_proxy_info_new(void);

/**
 * purple_proxy_info_set_proxy_type:
 * @info: The instance.
 * @proxy_type: The new type.
 *
 * Sets the type of @info.
 *
 * Since: 3.0
 */
PURPLE_AVAILABLE_IN_3_0
void purple_proxy_info_set_proxy_type(PurpleProxyInfo *info, PurpleProxyType proxy_type);

/**
 * purple_proxy_info_get_proxy_type:
 * @info: The instance.
 *
 * Gets the type of the proxy.
 *
 * Returns: The type of the proxy.
 *
 * Since: 3.0
 */
PURPLE_AVAILABLE_IN_3_0
PurpleProxyType purple_proxy_info_get_proxy_type(PurpleProxyInfo *info);

/**
 * purple_proxy_info_set_hostname:
 * @info: The instance.
 * @hostname: The new hostname.
 *
 * Sets the hostname for the proxy.
 *
 * Since: 3.0
 */
PURPLE_AVAILABLE_IN_3_0
void purple_proxy_info_set_hostname(PurpleProxyInfo *info, const char *hostname);

/**
 * purple_proxy_info_get_hostname:
 * @info: The instance.
 *
 * Gets the hostname of the proxy.
 *
 * Returns: The hostname.
 *
 * Since: 3.0
 */
PURPLE_AVAILABLE_IN_3_0
const char *purple_proxy_info_get_hostname(PurpleProxyInfo *info);

/**
 * purple_proxy_info_set_port:
 * @info: The instance.
 * @port: The new port.
 *
 * Sets the port for the proxy.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_ALL
void purple_proxy_info_set_port(PurpleProxyInfo *info, int port);

/**
 * purple_proxy_info_get_port:
 * @info: The instance.
 *
 * Gets the port of the proxy.
 *
 * Returns: The port of the proxy.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_ALL
int purple_proxy_info_get_port(PurpleProxyInfo *info);

/**
 * purple_proxy_info_set_username:
 * @info: The instance.
 * @username: The new username.
 *
 * Sets the username of the proxy.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_ALL
void purple_proxy_info_set_username(PurpleProxyInfo *info, const char *username);

/**
 * purple_proxy_info_get_username:
 * @info: The instance.
 *
 * Gets the username of the proxy.
 *
 * Returns: The username of the proxy.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_ALL
const char *purple_proxy_info_get_username(PurpleProxyInfo *info);

/**
 * purple_proxy_info_set_password:
 * @info: The instance.
 * @password: The new password.
 *
 * Sets the password for the proxy.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_ALL
void purple_proxy_info_set_password(PurpleProxyInfo *info, const char *password);

/**
 * purple_proxy_info_get_password:
 * @info: The instance.
 *
 * Gets the password of the proxy.
 *
 * Returns: The password of the proxy.
 *
 * Since: 2.0
 */
PURPLE_AVAILABLE_IN_ALL
const char *purple_proxy_info_get_password(PurpleProxyInfo *info);

G_END_DECLS

#endif /* PURPLE_PROXY_INFO_H */

mercurial