| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  | /* GIO - GLib Input, Output and Streaming Library
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Copyright (C) 2010 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 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 | 
					
						
							| 
									
										
										
										
											2014-01-23 12:58:29 +01:00
										 |  |  |  * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Author: Nicolas Dufresne <nicolas.dufresne@collabora.co.uk> | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "config.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "gproxyresolver.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <glib.h>
 | 
					
						
							|  |  |  | #include "glibintl.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "gasyncresult.h"
 | 
					
						
							|  |  |  | #include "gcancellable.h"
 | 
					
						
							|  |  |  | #include "giomodule.h"
 | 
					
						
							|  |  |  | #include "giomodule-priv.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * SECTION:gproxyresolver | 
					
						
							|  |  |  |  * @short_description: Asynchronous and cancellable network proxy resolver | 
					
						
							|  |  |  |  * @include: gio/gio.h | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * #GProxyResolver provides synchronous and asynchronous network proxy | 
					
						
							| 
									
										
										
										
											2011-06-06 10:22:40 -04:00
										 |  |  |  * resolution. #GProxyResolver is used within #GSocketClient through | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * the method g_socket_connectable_proxy_enumerate(). | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-05 16:20:43 +01:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * GProxyResolverInterface: | 
					
						
							|  |  |  |  * @g_iface: The parent interface. | 
					
						
							|  |  |  |  * @is_supported: the virtual function pointer for g_proxy_resolver_is_supported() | 
					
						
							|  |  |  |  * @lookup: the virtual function pointer for g_proxy_resolver_lookup() | 
					
						
							|  |  |  |  * @lookup_async: the virtual function pointer for | 
					
						
							|  |  |  |  *  g_proxy_resolver_lookup_async() | 
					
						
							|  |  |  |  * @lookup_finish: the virtual function pointer for | 
					
						
							|  |  |  |  *  g_proxy_resolver_lookup_finish() | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The virtual function table for #GProxyResolver. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  | G_DEFINE_INTERFACE (GProxyResolver, g_proxy_resolver, G_TYPE_OBJECT) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void | 
					
						
							|  |  |  | g_proxy_resolver_default_init (GProxyResolverInterface *iface) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * g_proxy_resolver_get_default: | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Gets the default #GProxyResolver for the system. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  * Returns: (transfer none): the default #GProxyResolver. | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | GProxyResolver * | 
					
						
							|  |  |  | g_proxy_resolver_get_default (void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2011-06-21 18:21:27 -04:00
										 |  |  |   return _g_io_module_get_default (G_PROXY_RESOLVER_EXTENSION_POINT_NAME, | 
					
						
							|  |  |  | 				   "GIO_USE_PROXY_RESOLVER", | 
					
						
							|  |  |  | 				   (GIOModuleVerifyFunc)g_proxy_resolver_is_supported); | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * g_proxy_resolver_is_supported: | 
					
						
							|  |  |  |  * @resolver: a #GProxyResolver | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Checks if @resolver can be used on this system. (This is used | 
					
						
							|  |  |  |  * internally; g_proxy_resolver_get_default() will only return a proxy | 
					
						
							|  |  |  |  * resolver that returns %TRUE for this method.) | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  * Returns: %TRUE if @resolver is supported. | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | gboolean | 
					
						
							|  |  |  | g_proxy_resolver_is_supported (GProxyResolver *resolver) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   GProxyResolverInterface *iface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   g_return_val_if_fail (G_IS_PROXY_RESOLVER (resolver), FALSE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   iface = G_PROXY_RESOLVER_GET_IFACE (resolver); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return (* iface->is_supported) (resolver); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * g_proxy_resolver_lookup: | 
					
						
							|  |  |  |  * @resolver: a #GProxyResolver | 
					
						
							|  |  |  |  * @uri: a URI representing the destination to connect to | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Looks into the system proxy configuration to determine what proxy, | 
					
						
							| 
									
										
										
										
											2014-02-06 08:04:52 -05:00
										 |  |  |  * if any, to use to connect to @uri. The returned proxy URIs are of | 
					
						
							| 
									
										
										
										
											2014-02-09 02:07:26 -05:00
										 |  |  |  * the form `<protocol>://[user[:password]@]host:port` or
 | 
					
						
							|  |  |  |  * `direct://`, where <protocol> could be http, rtsp, socks
 | 
					
						
							| 
									
										
										
										
											2014-02-06 08:04:52 -05:00
										 |  |  |  * or other proxying protocol. | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * If you don't know what network protocol is being used on the | 
					
						
							| 
									
										
										
										
											2014-02-06 08:04:52 -05:00
										 |  |  |  * socket, you should use `none` as the URI protocol. | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * In this case, the resolver might still return a generic proxy type | 
					
						
							|  |  |  |  * (such as SOCKS), but would not return protocol-specific proxy types | 
					
						
							|  |  |  |  * (such as http). | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-06 08:04:52 -05:00
										 |  |  |  * `direct://` is used when no proxy is needed.
 | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * Direct connection should not be attempted unless it is part of the | 
					
						
							|  |  |  |  * returned array of proxies. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  * Returns: (transfer full) (array zero-terminated=1): A | 
					
						
							| 
									
										
										
										
											2010-12-29 15:26:21 +01:00
										 |  |  |  *               NULL-terminated array of proxy URIs. Must be freed | 
					
						
							|  |  |  |  *               with g_strfreev(). | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | gchar ** | 
					
						
							|  |  |  | g_proxy_resolver_lookup (GProxyResolver  *resolver, | 
					
						
							|  |  |  | 			 const gchar     *uri, | 
					
						
							|  |  |  | 			 GCancellable    *cancellable, | 
					
						
							|  |  |  | 			 GError         **error) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   GProxyResolverInterface *iface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   g_return_val_if_fail (G_IS_PROXY_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |   g_return_val_if_fail (uri != NULL, NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   iface = G_PROXY_RESOLVER_GET_IFACE (resolver); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return (* iface->lookup) (resolver, uri, cancellable, error); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * g_proxy_resolver_lookup_async: | 
					
						
							|  |  |  |  * @resolver: a #GProxyResolver | 
					
						
							|  |  |  |  * @uri: a URI representing the destination to connect to | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2010-12-29 15:26:21 +01:00
										 |  |  |  * @callback: (scope async): callback to call after resolution completes | 
					
						
							|  |  |  |  * @user_data: (closure): data for @callback | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Asynchronous lookup of proxy. See g_proxy_resolver_lookup() for more | 
					
						
							|  |  |  |  * details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void | 
					
						
							|  |  |  | g_proxy_resolver_lookup_async (GProxyResolver      *resolver, | 
					
						
							|  |  |  | 			       const gchar         *uri, | 
					
						
							|  |  |  | 			       GCancellable        *cancellable, | 
					
						
							|  |  |  | 			       GAsyncReadyCallback  callback, | 
					
						
							|  |  |  | 			       gpointer             user_data) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   GProxyResolverInterface *iface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   g_return_if_fail (G_IS_PROXY_RESOLVER (resolver)); | 
					
						
							|  |  |  |   g_return_if_fail (uri != NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   iface = G_PROXY_RESOLVER_GET_IFACE (resolver); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   (* iface->lookup_async) (resolver, uri, cancellable, callback, user_data); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * g_proxy_resolver_lookup_finish: | 
					
						
							|  |  |  |  * @resolver: a #GProxyResolver | 
					
						
							|  |  |  |  * @result: the result passed to your #GAsyncReadyCallback | 
					
						
							|  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Call this function to obtain the array of proxy URIs when | 
					
						
							|  |  |  |  * g_proxy_resolver_lookup_async() is complete. See | 
					
						
							|  |  |  |  * g_proxy_resolver_lookup() for more details. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  * Returns: (transfer full) (array zero-terminated=1): A | 
					
						
							| 
									
										
										
										
											2010-12-29 15:26:21 +01:00
										 |  |  |  *               NULL-terminated array of proxy URIs. Must be freed | 
					
						
							|  |  |  |  *               with g_strfreev(). | 
					
						
							| 
									
										
										
										
											2010-05-07 15:55:54 -04:00
										 |  |  |  * | 
					
						
							|  |  |  |  * Since: 2.26 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | gchar ** | 
					
						
							|  |  |  | g_proxy_resolver_lookup_finish (GProxyResolver     *resolver, | 
					
						
							|  |  |  | 				GAsyncResult       *result, | 
					
						
							|  |  |  | 				GError            **error) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   GProxyResolverInterface *iface; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   g_return_val_if_fail (G_IS_PROXY_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   iface = G_PROXY_RESOLVER_GET_IFACE (resolver); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return (* iface->lookup_finish) (resolver, result, error); | 
					
						
							|  |  |  | } |