| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | /* -*- mode: C; c-file-style: "gnu"; indent-tabs-mode: nil; -*- */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /* GIO - GLib Input, Output and Streaming Library
 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * Copyright (C) 2008 Red Hat, Inc. | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * Copyright (C) 2018 Igalia S.L. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2022-05-18 09:12:45 +01:00
										 |  |  |  |  * SPDX-License-Identifier: LGPL-2.1-or-later | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * 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 | 
					
						
							| 
									
										
										
										
											2017-05-27 18:21:30 +02:00
										 |  |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * 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/>.
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  */ | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include "config.h"
 | 
					
						
							|  |  |  |  | #include <glib.h>
 | 
					
						
							|  |  |  |  | #include "glibintl.h"
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include "gresolver.h"
 | 
					
						
							|  |  |  |  | #include "gnetworkingprivate.h"
 | 
					
						
							|  |  |  |  | #include "gasyncresult.h"
 | 
					
						
							|  |  |  |  | #include "ginetaddress.h"
 | 
					
						
							| 
									
										
										
										
											2012-08-02 15:48:22 -04:00
										 |  |  |  | #include "gtask.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | #include "gsrvtarget.h"
 | 
					
						
							| 
									
										
										
										
											2011-08-31 14:33:33 -04:00
										 |  |  |  | #include "gthreadedresolver.h"
 | 
					
						
							| 
									
										
										
										
											2017-01-03 16:26:38 +01:00
										 |  |  |  | #include "gioerror.h"
 | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  | #include "gcancellable.h"
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | #ifdef G_OS_UNIX
 | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | #include <sys/stat.h>
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | #endif
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | #include <stdlib.h>
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2023-10-25 15:05:24 +01:00
										 |  |  |  |  * GResolver: | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * The object that handles DNS resolution. Use [func@Gio.Resolver.get_default] | 
					
						
							|  |  |  |  |  * to get the default resolver. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * `GResolver` provides cancellable synchronous and asynchronous DNS | 
					
						
							|  |  |  |  |  * resolution, for hostnames ([method@Gio.Resolver.lookup_by_address], | 
					
						
							|  |  |  |  |  * [method@Gio.Resolver.lookup_by_name] and their async variants) and SRV | 
					
						
							|  |  |  |  |  * (service) records ([method@Gio.Resolver.lookup_service]). | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-10-25 15:05:24 +01:00
										 |  |  |  |  * [class@Gio.NetworkAddress] and [class@Gio.NetworkService] provide wrappers | 
					
						
							|  |  |  |  |  * around `GResolver` functionality that also implement | 
					
						
							|  |  |  |  |  * [iface@Gio.SocketConnectable], making it easy to connect to a remote | 
					
						
							|  |  |  |  |  * host/service. | 
					
						
							| 
									
										
										
										
											2008-12-29 13:38:28 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-10-25 15:05:24 +01:00
										 |  |  |  |  * The default resolver (see [func@Gio.Resolver.get_default]) has a timeout of | 
					
						
							|  |  |  |  |  * 30s set on it since GLib 2.78. Earlier versions of GLib did not support | 
					
						
							|  |  |  |  |  * resolver timeouts. | 
					
						
							| 
									
										
										
										
											2023-04-26 12:53:37 +01:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-10-25 15:05:24 +01:00
										 |  |  |  |  * This is an abstract type; subclasses of it implement different resolvers for | 
					
						
							|  |  |  |  |  * different platforms and situations. | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  | typedef enum { | 
					
						
							|  |  |  |  |   PROP_TIMEOUT = 1, | 
					
						
							|  |  |  |  | } GResolverProperty; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static GParamSpec *props[PROP_TIMEOUT + 1] = { NULL, }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | enum { | 
					
						
							|  |  |  |  |   RELOAD, | 
					
						
							|  |  |  |  |   LAST_SIGNAL | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static guint signals[LAST_SIGNAL] = { 0 }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | struct _GResolverPrivate { | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  |   unsigned timeout_ms; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | #ifdef G_OS_UNIX
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |   GMutex mutex; | 
					
						
							|  |  |  |  |   time_t resolv_conf_timestamp;  /* protected by @mutex */ | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | #endif
 | 
					
						
							|  |  |  |  | }; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-30 14:41:12 +02:00
										 |  |  |  | G_DEFINE_ABSTRACT_TYPE_WITH_CODE (GResolver, g_resolver, G_TYPE_OBJECT, | 
					
						
							|  |  |  |  |                                   G_ADD_PRIVATE (GResolver) | 
					
						
							|  |  |  |  |                                   g_networking_init ();) | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  | static GList * | 
					
						
							|  |  |  |  | srv_records_to_targets (GList *records) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   const gchar *hostname; | 
					
						
							|  |  |  |  |   guint16 port, priority, weight; | 
					
						
							|  |  |  |  |   GSrvTarget *target; | 
					
						
							|  |  |  |  |   GList *l; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   for (l = records; l != NULL; l = g_list_next (l)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_variant_get (l->data, "(qqq&s)", &priority, &weight, &port, &hostname); | 
					
						
							|  |  |  |  |       target = g_srv_target_new (hostname, port, priority, weight); | 
					
						
							|  |  |  |  |       g_variant_unref (l->data); | 
					
						
							|  |  |  |  |       l->data = target; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return g_srv_target_list_sort (records); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static GList * | 
					
						
							|  |  |  |  | g_resolver_real_lookup_service (GResolver            *resolver, | 
					
						
							|  |  |  |  |                                 const gchar          *rrname, | 
					
						
							|  |  |  |  |                                 GCancellable         *cancellable, | 
					
						
							|  |  |  |  |                                 GError              **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *records; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   records = G_RESOLVER_GET_CLASS (resolver)->lookup_records (resolver, | 
					
						
							|  |  |  |  |                                                              rrname, | 
					
						
							|  |  |  |  |                                                              G_RESOLVER_RECORD_SRV, | 
					
						
							|  |  |  |  |                                                              cancellable, | 
					
						
							|  |  |  |  |                                                              error); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return srv_records_to_targets (records); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_resolver_real_lookup_service_async (GResolver            *resolver, | 
					
						
							|  |  |  |  |                                       const gchar          *rrname, | 
					
						
							|  |  |  |  |                                       GCancellable         *cancellable, | 
					
						
							|  |  |  |  |                                       GAsyncReadyCallback   callback, | 
					
						
							|  |  |  |  |                                       gpointer              user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   G_RESOLVER_GET_CLASS (resolver)->lookup_records_async (resolver, | 
					
						
							|  |  |  |  |                                                          rrname, | 
					
						
							|  |  |  |  |                                                          G_RESOLVER_RECORD_SRV, | 
					
						
							|  |  |  |  |                                                          cancellable, | 
					
						
							|  |  |  |  |                                                          callback, | 
					
						
							|  |  |  |  |                                                          user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static GList * | 
					
						
							|  |  |  |  | g_resolver_real_lookup_service_finish (GResolver            *resolver, | 
					
						
							|  |  |  |  |                                        GAsyncResult         *result, | 
					
						
							|  |  |  |  |                                        GError              **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *records; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   records = G_RESOLVER_GET_CLASS (resolver)->lookup_records_finish (resolver, | 
					
						
							|  |  |  |  |                                                                     result, | 
					
						
							|  |  |  |  |                                                                     error); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return srv_records_to_targets (records); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_resolver_get_property (GObject    *object, | 
					
						
							|  |  |  |  |                          guint       prop_id, | 
					
						
							|  |  |  |  |                          GValue     *value, | 
					
						
							|  |  |  |  |                          GParamSpec *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GResolver *self = G_RESOLVER (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   switch ((GResolverProperty) prop_id) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |     case PROP_TIMEOUT: | 
					
						
							|  |  |  |  |       g_value_set_uint (value, g_resolver_get_timeout (self)); | 
					
						
							|  |  |  |  |       break; | 
					
						
							|  |  |  |  |     default: | 
					
						
							|  |  |  |  |       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_resolver_set_property (GObject      *object, | 
					
						
							|  |  |  |  |                          guint         prop_id, | 
					
						
							|  |  |  |  |                          const GValue *value, | 
					
						
							|  |  |  |  |                          GParamSpec   *pspec) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GResolver *self = G_RESOLVER (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   switch ((GResolverProperty) prop_id) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |     case PROP_TIMEOUT: | 
					
						
							|  |  |  |  |       g_resolver_set_timeout (self, g_value_get_uint (value)); | 
					
						
							|  |  |  |  |       break; | 
					
						
							|  |  |  |  |     default: | 
					
						
							|  |  |  |  |       G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_resolver_finalize (GObject *object) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  | #ifdef G_OS_UNIX
 | 
					
						
							|  |  |  |  |   GResolver *resolver = G_RESOLVER (object); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_mutex_clear (&resolver->priv->mutex); | 
					
						
							|  |  |  |  | #endif
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   G_OBJECT_CLASS (g_resolver_parent_class)->finalize (object); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | static void | 
					
						
							|  |  |  |  | g_resolver_class_init (GResolverClass *resolver_class) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |   GObjectClass *object_class = G_OBJECT_CLASS (resolver_class); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  |   object_class->get_property = g_resolver_get_property; | 
					
						
							|  |  |  |  |   object_class->set_property = g_resolver_set_property; | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |   object_class->finalize = g_resolver_finalize; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |   /* Automatically pass these over to the lookup_records methods */ | 
					
						
							|  |  |  |  |   resolver_class->lookup_service = g_resolver_real_lookup_service; | 
					
						
							|  |  |  |  |   resolver_class->lookup_service_async = g_resolver_real_lookup_service_async; | 
					
						
							|  |  |  |  |   resolver_class->lookup_service_finish = g_resolver_real_lookup_service_finish; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  |   /**
 | 
					
						
							|  |  |  |  |    * GResolver:timeout: | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * The timeout applied to all resolver lookups, in milliseconds. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * This may be changed through the lifetime of the #GResolver. The new value | 
					
						
							|  |  |  |  |    * will apply to any lookups started after the change, but not to any | 
					
						
							|  |  |  |  |    * already-ongoing lookups. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * If this is `0`, no timeout is applied to lookups. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * No timeout was applied to lookups before this property was added in | 
					
						
							|  |  |  |  |    * GLib 2.78. | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * Since: 2.78 | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   props[PROP_TIMEOUT] = | 
					
						
							| 
									
										
										
										
											2023-04-28 01:59:26 +02:00
										 |  |  |  |     g_param_spec_uint ("timeout", NULL, NULL, | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  |                        0, G_MAXUINT, 0, | 
					
						
							|  |  |  |  |                        G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS | G_PARAM_EXPLICIT_NOTIFY); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_object_class_install_properties (object_class, G_N_ELEMENTS (props), props); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  |   /**
 | 
					
						
							|  |  |  |  |    * GResolver::reload: | 
					
						
							|  |  |  |  |    * @resolver: a #GResolver | 
					
						
							|  |  |  |  |    * | 
					
						
							|  |  |  |  |    * Emitted when the resolver notices that the system resolver | 
					
						
							|  |  |  |  |    * configuration has changed. | 
					
						
							|  |  |  |  |    **/ | 
					
						
							|  |  |  |  |   signals[RELOAD] = | 
					
						
							|  |  |  |  |     g_signal_new (I_("reload"), | 
					
						
							|  |  |  |  | 		  G_TYPE_RESOLVER, | 
					
						
							|  |  |  |  | 		  G_SIGNAL_RUN_LAST, | 
					
						
							|  |  |  |  | 		  G_STRUCT_OFFSET (GResolverClass, reload), | 
					
						
							|  |  |  |  | 		  NULL, NULL, | 
					
						
							| 
									
										
										
										
											2019-05-30 19:13:37 -07:00
										 |  |  |  | 		  NULL, | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | 		  G_TYPE_NONE, 0); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | g_resolver_init (GResolver *resolver) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | #ifdef G_OS_UNIX
 | 
					
						
							|  |  |  |  |   struct stat st; | 
					
						
							|  |  |  |  | #endif
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-24 15:43:04 +01:00
										 |  |  |  |   resolver->priv = g_resolver_get_instance_private (resolver); | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | #ifdef G_OS_UNIX
 | 
					
						
							|  |  |  |  |   if (stat (_PATH_RESCONF, &st) == 0) | 
					
						
							|  |  |  |  |     resolver->priv->resolv_conf_timestamp = st.st_mtime; | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_mutex_init (&resolver->priv->mutex); | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-20 12:16:18 +03:00
										 |  |  |  | G_LOCK_DEFINE_STATIC (default_resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | static GResolver *default_resolver; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_get_default: | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Gets the default #GResolver. You should unref it when you are done | 
					
						
							|  |  |  |  |  * with it. #GResolver may use its reference count as a hint about how | 
					
						
							| 
									
										
										
										
											2011-10-05 11:45:51 -04:00
										 |  |  |  |  * many threads it should allocate for concurrent DNS resolutions. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  |  * Returns: (transfer full): the default #GResolver. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-27 18:20:08 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | GResolver * | 
					
						
							|  |  |  |  | g_resolver_get_default (void) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2016-10-20 12:16:18 +03:00
										 |  |  |  |   GResolver *ret; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   G_LOCK (default_resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |   if (!default_resolver) | 
					
						
							| 
									
										
										
										
											2023-04-26 12:53:37 +01:00
										 |  |  |  |     default_resolver = g_object_new (G_TYPE_THREADED_RESOLVER, | 
					
						
							|  |  |  |  |                                      "timeout", 30000, | 
					
						
							|  |  |  |  |                                      NULL); | 
					
						
							| 
									
										
										
										
											2016-10-20 12:16:18 +03:00
										 |  |  |  |   ret = g_object_ref (default_resolver); | 
					
						
							|  |  |  |  |   G_UNLOCK (default_resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-20 12:16:18 +03:00
										 |  |  |  |   return ret; | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_set_default: | 
					
						
							|  |  |  |  |  * @resolver: the new default #GResolver | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Sets @resolver to be the application's default resolver (reffing | 
					
						
							|  |  |  |  |  * @resolver, and unreffing the previous default resolver, if any). | 
					
						
							|  |  |  |  |  * Future calls to g_resolver_get_default() will return this resolver. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * This can be used if an application wants to perform any sort of DNS | 
					
						
							|  |  |  |  |  * caching or "pinning"; it can implement its own #GResolver that | 
					
						
							|  |  |  |  |  * calls the original default resolver for DNS operations, and | 
					
						
							|  |  |  |  |  * implements its own cache policies on top of that, and then set | 
					
						
							|  |  |  |  |  * itself as the default resolver for all later code to use. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_set_default (GResolver *resolver) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2016-10-20 12:16:18 +03:00
										 |  |  |  |   G_LOCK (default_resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |   if (default_resolver) | 
					
						
							|  |  |  |  |     g_object_unref (default_resolver); | 
					
						
							|  |  |  |  |   default_resolver = g_object_ref (resolver); | 
					
						
							| 
									
										
										
										
											2016-10-20 12:16:18 +03:00
										 |  |  |  |   G_UNLOCK (default_resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | static void | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  | maybe_emit_reload (GResolver *resolver) | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  | { | 
					
						
							|  |  |  |  | #ifdef G_OS_UNIX
 | 
					
						
							|  |  |  |  |   struct stat st; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (stat (_PATH_RESCONF, &st) == 0) | 
					
						
							|  |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |       g_mutex_lock (&resolver->priv->mutex); | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  |       if (st.st_mtime != resolver->priv->resolv_conf_timestamp) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           resolver->priv->resolv_conf_timestamp = st.st_mtime; | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |           g_mutex_unlock (&resolver->priv->mutex); | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  |           g_signal_emit (resolver, signals[RELOAD], 0); | 
					
						
							|  |  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |       else | 
					
						
							|  |  |  |  |         g_mutex_unlock (&resolver->priv->mutex); | 
					
						
							| 
									
										
										
										
											2009-08-19 12:07:53 -04:00
										 |  |  |  |     } | 
					
						
							|  |  |  |  | #endif
 | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-04-14 11:27:57 -04:00
										 |  |  |  | /* filter out duplicates, cf. https://bugzilla.gnome.org/show_bug.cgi?id=631379 */ | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | remove_duplicates (GList *addrs) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *l; | 
					
						
							|  |  |  |  |   GList *ll; | 
					
						
							|  |  |  |  |   GList *lll; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* TODO: if this is too slow (it's O(n^2) but n is typically really
 | 
					
						
							|  |  |  |  |    * small), we can do something more clever but note that we must not | 
					
						
							|  |  |  |  |    * change the order of elements... | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   for (l = addrs; l != NULL; l = l->next) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GInetAddress *address = G_INET_ADDRESS (l->data); | 
					
						
							|  |  |  |  |       for (ll = l->next; ll != NULL; ll = lll) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           GInetAddress *other_address = G_INET_ADDRESS (ll->data); | 
					
						
							|  |  |  |  |           lll = ll->next; | 
					
						
							|  |  |  |  |           if (g_inet_address_equal (address, other_address)) | 
					
						
							|  |  |  |  |             { | 
					
						
							|  |  |  |  |               g_object_unref (other_address); | 
					
						
							|  |  |  |  |               /* we never return the first element */ | 
					
						
							|  |  |  |  |               g_warn_if_fail (g_list_delete_link (addrs, ll) == addrs); | 
					
						
							|  |  |  |  |             } | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-05 08:53:44 -05:00
										 |  |  |  | static gboolean | 
					
						
							|  |  |  |  | hostname_is_localhost (const char *hostname) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   size_t len = strlen (hostname); | 
					
						
							|  |  |  |  |   const char *p; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Match "localhost", "localhost.", "*.localhost" and "*.localhost." */ | 
					
						
							|  |  |  |  |   if (len < strlen ("localhost")) | 
					
						
							|  |  |  |  |     return FALSE; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (hostname[len - 1] == '.') | 
					
						
							|  |  |  |  |       len--; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Scan backwards in @hostname to find the right-most dot (excluding the final dot, if it exists, as it was chopped off above).
 | 
					
						
							|  |  |  |  |    * We can’t use strrchr() because because we need to operate with string lengths. | 
					
						
							|  |  |  |  |    * End with @p pointing to the character after the right-most dot. */ | 
					
						
							|  |  |  |  |   p = hostname + len - 1; | 
					
						
							|  |  |  |  |   while (p >= hostname) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       if (*p == '.') | 
					
						
							|  |  |  |  |        { | 
					
						
							|  |  |  |  |          p++; | 
					
						
							|  |  |  |  |          break; | 
					
						
							|  |  |  |  |        } | 
					
						
							|  |  |  |  |       else if (p == hostname) | 
					
						
							|  |  |  |  |         break; | 
					
						
							|  |  |  |  |       p--; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   len -= p - hostname; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return g_ascii_strncasecmp (p, "localhost", MAX (len, strlen ("localhost"))) == 0; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  | /* Note that this does not follow the "FALSE means @error is set"
 | 
					
						
							|  |  |  |  |  * convention. The return value tells the caller whether it should | 
					
						
							|  |  |  |  |  * return @addrs and @error to the caller right away, or if it should | 
					
						
							|  |  |  |  |  * continue and trying to resolve the name as a hostname. | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | static gboolean | 
					
						
							| 
									
										
										
										
											2019-02-05 08:53:44 -05:00
										 |  |  |  | handle_ip_address_or_localhost (const char                *hostname, | 
					
						
							|  |  |  |  |                                 GList                    **addrs, | 
					
						
							|  |  |  |  |                                 GResolverNameLookupFlags   flags, | 
					
						
							|  |  |  |  |                                 GError                   **error) | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   GInetAddress *addr; | 
					
						
							| 
									
										
										
										
											2015-01-19 11:03:57 +08:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-02 12:35:43 +00:00
										 |  |  |  | #ifndef G_OS_WIN32
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |   struct in_addr ip4addr; | 
					
						
							| 
									
										
										
										
											2014-08-02 12:35:43 +00:00
										 |  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   addr = g_inet_address_new_from_string (hostname); | 
					
						
							|  |  |  |  |   if (addr) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       *addrs = g_list_append (NULL, addr); | 
					
						
							|  |  |  |  |       return TRUE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   *addrs = NULL; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-19 11:03:57 +08:00
										 |  |  |  | #ifdef G_OS_WIN32
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Reject IPv6 addresses that have brackets ('[' or ']') and/or port numbers,
 | 
					
						
							|  |  |  |  |    * as no valid addresses should contain these at this point. | 
					
						
							|  |  |  |  |    * Non-standard IPv4 addresses would be rejected during the call to | 
					
						
							|  |  |  |  |    * getaddrinfo() later. | 
					
						
							|  |  |  |  |    */ | 
					
						
							|  |  |  |  |   if (strrchr (hostname, '[') != NULL || | 
					
						
							|  |  |  |  |       strrchr (hostname, ']') != NULL) | 
					
						
							|  |  |  |  | #else
 | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |   /* Reject non-standard IPv4 numbers-and-dots addresses.
 | 
					
						
							|  |  |  |  |    * g_inet_address_new_from_string() will have accepted any "real" IP | 
					
						
							|  |  |  |  |    * address, so if inet_aton() succeeds, then it's an address we want | 
					
						
							| 
									
										
										
										
											2015-01-19 11:03:57 +08:00
										 |  |  |  |    * to reject. | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |    */ | 
					
						
							|  |  |  |  |   if (inet_aton (hostname, &ip4addr)) | 
					
						
							| 
									
										
										
										
											2015-01-19 11:03:57 +08:00
										 |  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2019-03-21 11:51:37 +00:00
										 |  |  |  | #ifdef G_OS_WIN32
 | 
					
						
							|  |  |  |  |       gchar *error_message = g_win32_error_message (WSAHOST_NOT_FOUND); | 
					
						
							|  |  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2019-03-22 13:30:43 +00:00
										 |  |  |  |       gchar *error_message = g_locale_to_utf8 (gai_strerror (EAI_NONAME), -1, NULL, NULL, NULL); | 
					
						
							|  |  |  |  |       if (error_message == NULL) | 
					
						
							|  |  |  |  |         error_message = g_strdup ("[Invalid UTF-8]"); | 
					
						
							| 
									
										
										
										
											2019-03-21 11:51:37 +00:00
										 |  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |       g_set_error (error, G_RESOLVER_ERROR, G_RESOLVER_ERROR_NOT_FOUND, | 
					
						
							| 
									
										
										
										
											2016-09-30 05:47:15 +02:00
										 |  |  |  |                    _("Error resolving “%s”: %s"), | 
					
						
							| 
									
										
										
										
											2019-03-21 11:51:37 +00:00
										 |  |  |  |                    hostname, error_message); | 
					
						
							|  |  |  |  |       g_free (error_message); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |       return TRUE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-05 08:53:44 -05:00
										 |  |  |  |   /* Always resolve localhost to a loopback address so it can be reliably considered secure.
 | 
					
						
							|  |  |  |  |      This behavior is being adopted by browsers: | 
					
						
							|  |  |  |  |      - https://w3c.github.io/webappsec-secure-contexts/
 | 
					
						
							|  |  |  |  |      - https://groups.google.com/a/chromium.org/forum/#!msg/blink-dev/RC9dSw-O3fE/E3_0XaT0BAAJ
 | 
					
						
							|  |  |  |  |      - https://chromium.googlesource.com/chromium/src.git/+/8da2a80724a9b896890602ff77ef2216cb951399
 | 
					
						
							|  |  |  |  |      - https://bugs.webkit.org/show_bug.cgi?id=171934
 | 
					
						
							|  |  |  |  |      - https://tools.ietf.org/html/draft-west-let-localhost-be-localhost-06
 | 
					
						
							|  |  |  |  |   */ | 
					
						
							|  |  |  |  |   if (hostname_is_localhost (hostname)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       if (flags & G_RESOLVER_NAME_LOOKUP_FLAGS_IPV6_ONLY) | 
					
						
							|  |  |  |  |         *addrs = g_list_append (*addrs, g_inet_address_new_loopback (G_SOCKET_FAMILY_IPV6));  | 
					
						
							|  |  |  |  |       if (flags & G_RESOLVER_NAME_LOOKUP_FLAGS_IPV4_ONLY) | 
					
						
							|  |  |  |  |         *addrs = g_list_append (*addrs, g_inet_address_new_loopback (G_SOCKET_FAMILY_IPV4)); | 
					
						
							|  |  |  |  |       if (*addrs == NULL) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           *addrs = g_list_append (*addrs, g_inet_address_new_loopback (G_SOCKET_FAMILY_IPV6)); | 
					
						
							|  |  |  |  |           *addrs = g_list_append (*addrs, g_inet_address_new_loopback (G_SOCKET_FAMILY_IPV4)); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       return TRUE; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |   return FALSE; | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-04-14 11:27:57 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  | static GList * | 
					
						
							|  |  |  |  | lookup_by_name_real (GResolver                 *resolver, | 
					
						
							|  |  |  |  |                      const gchar               *hostname, | 
					
						
							|  |  |  |  |                      GResolverNameLookupFlags   flags, | 
					
						
							|  |  |  |  |                      GCancellable              *cancellable, | 
					
						
							|  |  |  |  |                      GError                    **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *addrs; | 
					
						
							|  |  |  |  |   gchar *ascii_hostname = NULL; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (hostname != NULL, NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (cancellable == NULL || G_IS_CANCELLABLE (cancellable), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (error == NULL || *error == NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Check if @hostname is just an IP address */ | 
					
						
							| 
									
										
										
										
											2019-02-05 08:53:44 -05:00
										 |  |  |  |   if (handle_ip_address_or_localhost (hostname, &addrs, flags, error)) | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |     return addrs; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (g_hostname_is_non_ascii (hostname)) | 
					
						
							|  |  |  |  |     hostname = ascii_hostname = g_hostname_to_ascii (hostname); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (!hostname) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED, | 
					
						
							|  |  |  |  |                            _("Invalid hostname")); | 
					
						
							|  |  |  |  |       return NULL; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (flags != G_RESOLVER_NAME_LOOKUP_FLAGS_DEFAULT) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       if (!G_RESOLVER_GET_CLASS (resolver)->lookup_by_name_with_flags) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           g_set_error (error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, | 
					
						
							|  |  |  |  |                        /* Translators: The placeholder is for a function name. */ | 
					
						
							|  |  |  |  |                        _("%s not implemented"), "lookup_by_name_with_flags"); | 
					
						
							|  |  |  |  |           g_free (ascii_hostname); | 
					
						
							|  |  |  |  |           return NULL; | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       addrs = G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |         lookup_by_name_with_flags (resolver, hostname, flags, cancellable, error); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     addrs = G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |       lookup_by_name (resolver, hostname, cancellable, error); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   remove_duplicates (addrs); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_free (ascii_hostname); | 
					
						
							|  |  |  |  |   return addrs; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @hostname: the hostname to look up | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Synchronously resolves @hostname to determine its associated IP | 
					
						
							|  |  |  |  |  * address(es). @hostname may be an ASCII-only or UTF-8 hostname, or | 
					
						
							|  |  |  |  |  * the textual form of an IP address (in which case this just becomes | 
					
						
							|  |  |  |  |  * a wrapper around g_inet_address_new_from_string()). | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * On success, g_resolver_lookup_by_name() will return a non-empty #GList of | 
					
						
							| 
									
										
										
										
											2011-04-14 11:27:57 -04:00
										 |  |  |  |  * #GInetAddress, sorted in order of preference and guaranteed to not | 
					
						
							|  |  |  |  |  * contain duplicates. That is, if using the result to connect to | 
					
						
							|  |  |  |  |  * @hostname, you should attempt to connect to the first address | 
					
						
							|  |  |  |  |  * first, then the second if the first fails, etc. If you are using | 
					
						
							|  |  |  |  |  * the result to listen on a socket, it is appropriate to add each | 
					
						
							|  |  |  |  |  * result using e.g. g_socket_listener_add_address(). | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution fails, @error (if non-%NULL) will be set to a | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * value from #GResolverError and %NULL will be returned. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * If @cancellable is non-%NULL, it can be used to cancel the | 
					
						
							|  |  |  |  |  * operation, in which case @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-12-29 13:38:28 -05:00
										 |  |  |  |  * If you are planning to connect to a socket on the resolved IP | 
					
						
							|  |  |  |  |  * address, it may be easier to create a #GNetworkAddress and use its | 
					
						
							|  |  |  |  |  * #GSocketConnectable interface. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * Returns: (element-type GInetAddress) (transfer full): a non-empty #GList | 
					
						
							| 
									
										
										
										
											2010-09-24 15:51:26 -03:00
										 |  |  |  |  * of #GInetAddress, or %NULL on error. You | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * must unref each of the addresses and free the list when you are | 
					
						
							|  |  |  |  |  * done with it. (You can use g_resolver_free_addresses() to do this.) | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_by_name (GResolver     *resolver, | 
					
						
							|  |  |  |  |                            const gchar   *hostname, | 
					
						
							|  |  |  |  |                            GCancellable  *cancellable, | 
					
						
							|  |  |  |  |                            GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |   return lookup_by_name_real (resolver, | 
					
						
							|  |  |  |  |                               hostname, | 
					
						
							|  |  |  |  |                               G_RESOLVER_NAME_LOOKUP_FLAGS_DEFAULT, | 
					
						
							|  |  |  |  |                               cancellable, | 
					
						
							|  |  |  |  |                               error); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * g_resolver_lookup_by_name_with_flags: | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * @resolver: a #GResolver | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * @hostname: the hostname to look up | 
					
						
							|  |  |  |  |  * @flags: extra #GResolverNameLookupFlags for the lookup | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * @error: (nullable): return location for a #GError, or %NULL | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * This differs from g_resolver_lookup_by_name() in that you can modify | 
					
						
							|  |  |  |  |  * the lookup behavior with @flags. For example this can be used to limit | 
					
						
							| 
									
										
										
										
											2022-03-04 16:21:55 +00:00
										 |  |  |  |  * results with %G_RESOLVER_NAME_LOOKUP_FLAGS_IPV4_ONLY. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * Returns: (element-type GInetAddress) (transfer full): a non-empty #GList | 
					
						
							|  |  |  |  |  * of #GInetAddress, or %NULL on error. You | 
					
						
							|  |  |  |  |  * must unref each of the addresses and free the list when you are | 
					
						
							|  |  |  |  |  * done with it. (You can use g_resolver_free_addresses() to do this.) | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.60 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_by_name_with_flags (GResolver                 *resolver, | 
					
						
							|  |  |  |  |                                       const gchar               *hostname, | 
					
						
							|  |  |  |  |                                       GResolverNameLookupFlags   flags, | 
					
						
							|  |  |  |  |                                       GCancellable              *cancellable, | 
					
						
							|  |  |  |  |                                       GError                   **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   return lookup_by_name_real (resolver, | 
					
						
							|  |  |  |  |                               hostname, | 
					
						
							|  |  |  |  |                               flags, | 
					
						
							|  |  |  |  |                               cancellable, | 
					
						
							|  |  |  |  |                               error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static void | 
					
						
							|  |  |  |  | lookup_by_name_async_real (GResolver                *resolver, | 
					
						
							|  |  |  |  |                            const gchar              *hostname, | 
					
						
							|  |  |  |  |                            GResolverNameLookupFlags  flags, | 
					
						
							|  |  |  |  |                            GCancellable             *cancellable, | 
					
						
							|  |  |  |  |                            GAsyncReadyCallback       callback, | 
					
						
							|  |  |  |  |                            gpointer                  user_data) | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | { | 
					
						
							|  |  |  |  |   gchar *ascii_hostname = NULL; | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |   GList *addrs; | 
					
						
							|  |  |  |  |   GError *error = NULL; | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_RESOLVER (resolver)); | 
					
						
							|  |  |  |  |   g_return_if_fail (hostname != NULL); | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |   g_return_if_fail (!(flags & G_RESOLVER_NAME_LOOKUP_FLAGS_IPV4_ONLY && flags & G_RESOLVER_NAME_LOOKUP_FLAGS_IPV6_ONLY)); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   /* Check if @hostname is just an IP address */ | 
					
						
							| 
									
										
										
										
											2019-02-05 08:53:44 -05:00
										 |  |  |  |   if (handle_ip_address_or_localhost (hostname, &addrs, flags, &error)) | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |     { | 
					
						
							| 
									
										
										
										
											2012-08-02 15:48:22 -04:00
										 |  |  |  |       GTask *task; | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-08-02 15:48:22 -04:00
										 |  |  |  |       task = g_task_new (resolver, cancellable, callback, user_data); | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |       g_task_set_source_tag (task, lookup_by_name_async_real); | 
					
						
							| 
									
										
										
										
											2020-06-25 23:36:08 +01:00
										 |  |  |  |       g_task_set_name (task, "[gio] resolver lookup"); | 
					
						
							| 
									
										
										
										
											2013-08-20 21:36:25 -04:00
										 |  |  |  |       if (addrs) | 
					
						
							|  |  |  |  |         g_task_return_pointer (task, addrs, (GDestroyNotify) g_resolver_free_addresses); | 
					
						
							|  |  |  |  |       else | 
					
						
							|  |  |  |  |         g_task_return_error (task, error); | 
					
						
							| 
									
										
										
										
											2012-08-02 15:48:22 -04:00
										 |  |  |  |       g_object_unref (task); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |       return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (g_hostname_is_non_ascii (hostname)) | 
					
						
							|  |  |  |  |     hostname = ascii_hostname = g_hostname_to_ascii (hostname); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-12-07 17:44:08 +01:00
										 |  |  |  |   if (!hostname) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       GTask *task; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |       g_set_error_literal (&error, G_IO_ERROR, G_IO_ERROR_FAILED, | 
					
						
							|  |  |  |  |                            _("Invalid hostname")); | 
					
						
							|  |  |  |  |       task = g_task_new (resolver, cancellable, callback, user_data); | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |       g_task_set_source_tag (task, lookup_by_name_async_real); | 
					
						
							| 
									
										
										
										
											2020-06-25 23:36:08 +01:00
										 |  |  |  |       g_task_set_name (task, "[gio] resolver lookup"); | 
					
						
							| 
									
										
										
										
											2016-12-07 17:44:08 +01:00
										 |  |  |  |       g_task_return_error (task, error); | 
					
						
							|  |  |  |  |       g_object_unref (task); | 
					
						
							|  |  |  |  |       return; | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (flags != G_RESOLVER_NAME_LOOKUP_FLAGS_DEFAULT) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       if (G_RESOLVER_GET_CLASS (resolver)->lookup_by_name_with_flags_async == NULL) | 
					
						
							|  |  |  |  |         { | 
					
						
							|  |  |  |  |           GTask *task; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |           g_set_error (&error, G_IO_ERROR, G_IO_ERROR_NOT_SUPPORTED, | 
					
						
							|  |  |  |  |                        /* Translators: The placeholder is for a function name. */ | 
					
						
							|  |  |  |  |                        _("%s not implemented"), "lookup_by_name_with_flags_async"); | 
					
						
							|  |  |  |  |           task = g_task_new (resolver, cancellable, callback, user_data); | 
					
						
							|  |  |  |  |           g_task_set_source_tag (task, lookup_by_name_async_real); | 
					
						
							| 
									
										
										
										
											2020-06-25 23:36:08 +01:00
										 |  |  |  |           g_task_set_name (task, "[gio] resolver lookup"); | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |           g_task_return_error (task, error); | 
					
						
							|  |  |  |  |           g_object_unref (task); | 
					
						
							|  |  |  |  |         } | 
					
						
							|  |  |  |  |       else | 
					
						
							|  |  |  |  |         G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |           lookup_by_name_with_flags_async (resolver, hostname, flags, cancellable, callback, user_data); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |       lookup_by_name_async (resolver, hostname, cancellable, callback, user_data); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_free (ascii_hostname); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  | static GList * | 
					
						
							|  |  |  |  | lookup_by_name_finish_real (GResolver     *resolver, | 
					
						
							|  |  |  |  |                             GAsyncResult  *result, | 
					
						
							|  |  |  |  |                             GError       **error, | 
					
						
							|  |  |  |  |                             gboolean       with_flags) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *addrs; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_ASYNC_RESULT (result), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (error == NULL || *error == NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (g_async_result_legacy_propagate_error (result, error)) | 
					
						
							|  |  |  |  |     return NULL; | 
					
						
							|  |  |  |  |   else if (g_async_result_is_tagged (result, lookup_by_name_async_real)) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       /* Handle the stringified-IP-addr case */ | 
					
						
							|  |  |  |  |       return g_task_propagate_pointer (G_TASK (result), error); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (with_flags) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_assert (G_RESOLVER_GET_CLASS (resolver)->lookup_by_name_with_flags_finish != NULL); | 
					
						
							|  |  |  |  |       addrs = G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |         lookup_by_name_with_flags_finish (resolver, result, error); | 
					
						
							|  |  |  |  |     } | 
					
						
							|  |  |  |  |   else | 
					
						
							|  |  |  |  |     addrs = G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |       lookup_by_name_finish (resolver, result, error); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   remove_duplicates (addrs); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return addrs; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name_with_flags_async: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @hostname: the hostname to look up the address of | 
					
						
							|  |  |  |  |  * @flags: extra #GResolverNameLookupFlags for the lookup | 
					
						
							|  |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2023-02-20 14:43:02 -06:00
										 |  |  |  |  * @callback: (scope async) (closure user_data): callback to call after resolution completes | 
					
						
							|  |  |  |  |  * @user_data: data for @callback | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Begins asynchronously resolving @hostname to determine its | 
					
						
							|  |  |  |  |  * associated IP address(es), and eventually calls @callback, which | 
					
						
							|  |  |  |  |  * must call g_resolver_lookup_by_name_with_flags_finish() to get the result. | 
					
						
							|  |  |  |  |  * See g_resolver_lookup_by_name() for more details. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.60 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_lookup_by_name_with_flags_async (GResolver                *resolver, | 
					
						
							|  |  |  |  |                                             const gchar              *hostname, | 
					
						
							|  |  |  |  |                                             GResolverNameLookupFlags  flags, | 
					
						
							|  |  |  |  |                                             GCancellable             *cancellable, | 
					
						
							|  |  |  |  |                                             GAsyncReadyCallback       callback, | 
					
						
							|  |  |  |  |                                             gpointer                  user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   lookup_by_name_async_real (resolver, | 
					
						
							|  |  |  |  |                              hostname, | 
					
						
							|  |  |  |  |                              flags, | 
					
						
							|  |  |  |  |                              cancellable, | 
					
						
							|  |  |  |  |                              callback, | 
					
						
							|  |  |  |  |                              user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name_async: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @hostname: the hostname to look up the address of | 
					
						
							|  |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2023-02-20 14:43:02 -06:00
										 |  |  |  |  * @callback: (scope async) (closure user_data): callback to call after resolution completes | 
					
						
							|  |  |  |  |  * @user_data: data for @callback | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Begins asynchronously resolving @hostname to determine its | 
					
						
							|  |  |  |  |  * associated IP address(es), and eventually calls @callback, which | 
					
						
							|  |  |  |  |  * must call g_resolver_lookup_by_name_finish() to get the result. | 
					
						
							|  |  |  |  |  * See g_resolver_lookup_by_name() for more details. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_lookup_by_name_async (GResolver           *resolver, | 
					
						
							|  |  |  |  |                                  const gchar         *hostname, | 
					
						
							|  |  |  |  |                                  GCancellable        *cancellable, | 
					
						
							|  |  |  |  |                                  GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |  |                                  gpointer             user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   lookup_by_name_async_real (resolver, | 
					
						
							|  |  |  |  |                              hostname, | 
					
						
							|  |  |  |  |                              0, | 
					
						
							|  |  |  |  |                              cancellable, | 
					
						
							|  |  |  |  |                              callback, | 
					
						
							|  |  |  |  |                              user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name_finish: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @result: the result passed to your #GAsyncReadyCallback | 
					
						
							|  |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Retrieves the result of a call to | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name_async(). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution failed, @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * a value from #GResolverError. If the operation was cancelled, | 
					
						
							|  |  |  |  |  * @error will be set to %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  |  * Returns: (element-type GInetAddress) (transfer full): a #GList | 
					
						
							| 
									
										
										
										
											2010-09-24 15:51:26 -03:00
										 |  |  |  |  * of #GInetAddress, or %NULL on error. See g_resolver_lookup_by_name() | 
					
						
							|  |  |  |  |  * for more details. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_by_name_finish (GResolver     *resolver, | 
					
						
							|  |  |  |  |                                   GAsyncResult  *result, | 
					
						
							|  |  |  |  |                                   GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  |   return lookup_by_name_finish_real (resolver, | 
					
						
							|  |  |  |  |                                      result, | 
					
						
							|  |  |  |  |                                      error, | 
					
						
							|  |  |  |  |                                      FALSE); | 
					
						
							|  |  |  |  | } | 
					
						
							| 
									
										
										
										
											2011-04-14 11:27:57 -04:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-17 11:14:10 -04:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name_with_flags_finish: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @result: the result passed to your #GAsyncReadyCallback | 
					
						
							|  |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Retrieves the result of a call to | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name_with_flags_async(). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution failed, @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * a value from #GResolverError. If the operation was cancelled, | 
					
						
							|  |  |  |  |  * @error will be set to %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Returns: (element-type GInetAddress) (transfer full): a #GList | 
					
						
							|  |  |  |  |  * of #GInetAddress, or %NULL on error. See g_resolver_lookup_by_name() | 
					
						
							|  |  |  |  |  * for more details. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.60 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_by_name_with_flags_finish (GResolver     *resolver, | 
					
						
							|  |  |  |  |                                              GAsyncResult  *result, | 
					
						
							|  |  |  |  |                                              GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   return lookup_by_name_finish_real (resolver, | 
					
						
							|  |  |  |  |                                      result, | 
					
						
							|  |  |  |  |                                      error, | 
					
						
							|  |  |  |  |                                      TRUE); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-09-24 15:51:26 -03:00
										 |  |  |  |  * g_resolver_free_addresses: (skip) | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * @addresses: a #GList of #GInetAddress | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Frees @addresses (which should be the return value from | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_name() or g_resolver_lookup_by_name_finish()). | 
					
						
							|  |  |  |  |  * (This is a convenience method; you can also simply free the results | 
					
						
							|  |  |  |  |  * by hand.) | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_free_addresses (GList *addresses) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *a; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   for (a = addresses; a; a = a->next) | 
					
						
							|  |  |  |  |     g_object_unref (a->data); | 
					
						
							|  |  |  |  |   g_list_free (addresses); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_address: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @address: the address to reverse-resolve | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Synchronously reverse-resolves @address to determine its | 
					
						
							|  |  |  |  |  * associated hostname. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution fails, @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * a value from #GResolverError. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If @cancellable is non-%NULL, it can be used to cancel the | 
					
						
							|  |  |  |  |  * operation, in which case @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  |  * Returns: a hostname (either ASCII-only, or in ASCII-encoded | 
					
						
							| 
									
										
										
										
											2009-05-27 18:20:08 -04:00
										 |  |  |  |  *     form), or %NULL on error. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | gchar * | 
					
						
							|  |  |  |  | g_resolver_lookup_by_address (GResolver     *resolver, | 
					
						
							|  |  |  |  |                               GInetAddress  *address, | 
					
						
							|  |  |  |  |                               GCancellable  *cancellable, | 
					
						
							|  |  |  |  |                               GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_INET_ADDRESS (address), NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |   return G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_by_address (resolver, address, cancellable, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_address_async: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @address: the address to reverse-resolve | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2023-02-20 14:43:02 -06:00
										 |  |  |  |  * @callback: (scope async) (closure user_data): callback to call after resolution completes | 
					
						
							|  |  |  |  |  * @user_data: data for @callback | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Begins asynchronously reverse-resolving @address to determine its | 
					
						
							|  |  |  |  |  * associated hostname, and eventually calls @callback, which must | 
					
						
							|  |  |  |  |  * call g_resolver_lookup_by_address_finish() to get the final result. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_lookup_by_address_async (GResolver           *resolver, | 
					
						
							|  |  |  |  |                                     GInetAddress        *address, | 
					
						
							|  |  |  |  |                                     GCancellable        *cancellable, | 
					
						
							|  |  |  |  |                                     GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |  |                                     gpointer             user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_RESOLVER (resolver)); | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_INET_ADDRESS (address)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |   G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_by_address_async (resolver, address, cancellable, callback, user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_address_finish: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @result: the result passed to your #GAsyncReadyCallback | 
					
						
							|  |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Retrieves the result of a previous call to | 
					
						
							|  |  |  |  |  * g_resolver_lookup_by_address_async(). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution failed, @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * a value from #GResolverError. If the operation was cancelled, | 
					
						
							|  |  |  |  |  * @error will be set to %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  |  * Returns: a hostname (either ASCII-only, or in ASCII-encoded | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * form), or %NULL on error. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | gchar * | 
					
						
							|  |  |  |  | g_resolver_lookup_by_address_finish (GResolver     *resolver, | 
					
						
							|  |  |  |  |                                      GAsyncResult  *result, | 
					
						
							|  |  |  |  |                                      GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-10 09:00:45 -04:00
										 |  |  |  |   if (g_async_result_legacy_propagate_error (result, error)) | 
					
						
							|  |  |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   return G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_by_address_finish (resolver, result, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | static gchar * | 
					
						
							|  |  |  |  | g_resolver_get_service_rrname (const char *service, | 
					
						
							|  |  |  |  |                                const char *protocol, | 
					
						
							|  |  |  |  |                                const char *domain) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   gchar *rrname, *ascii_domain = NULL; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (g_hostname_is_non_ascii (domain)) | 
					
						
							|  |  |  |  |     domain = ascii_domain = g_hostname_to_ascii (domain); | 
					
						
							| 
									
										
										
										
											2016-12-07 17:39:56 +01:00
										 |  |  |  |   if (!domain) | 
					
						
							|  |  |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   rrname = g_strdup_printf ("_%s._%s.%s", service, protocol, domain); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_free (ascii_domain); | 
					
						
							|  |  |  |  |   return rrname; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_service: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @service: the service type to look up (eg, "ldap") | 
					
						
							|  |  |  |  |  * @protocol: the networking protocol to use for @service (eg, "tcp") | 
					
						
							|  |  |  |  |  * @domain: the DNS domain to look up the service in | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Synchronously performs a DNS SRV lookup for the given @service and | 
					
						
							|  |  |  |  |  * @protocol in the given @domain and returns an array of #GSrvTarget. | 
					
						
							|  |  |  |  |  * @domain may be an ASCII-only or UTF-8 hostname. Note also that the | 
					
						
							| 
									
										
										
										
											2014-01-31 20:34:33 -05:00
										 |  |  |  |  * @service and @protocol arguments do not include the leading underscore | 
					
						
							|  |  |  |  |  * that appears in the actual DNS entry. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * On success, g_resolver_lookup_service() will return a non-empty #GList of | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * #GSrvTarget, sorted in order of preference. (That is, you should | 
					
						
							|  |  |  |  |  * attempt to connect to the first target first, then the second if | 
					
						
							|  |  |  |  |  * the first fails, etc.) | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution fails, @error (if non-%NULL) will be set to | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * a value from #GResolverError and %NULL will be returned. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * If @cancellable is non-%NULL, it can be used to cancel the | 
					
						
							|  |  |  |  |  * operation, in which case @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-12-29 13:38:28 -05:00
										 |  |  |  |  * If you are planning to connect to the service, it is usually easier | 
					
						
							|  |  |  |  |  * to create a #GNetworkService and use its #GSocketConnectable | 
					
						
							|  |  |  |  |  * interface. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * Returns: (element-type GSrvTarget) (transfer full): a non-empty #GList of | 
					
						
							|  |  |  |  |  * #GSrvTarget, or %NULL on error. You must free each of the targets and the | 
					
						
							|  |  |  |  |  * list when you are done with it. (You can use g_resolver_free_targets() to do | 
					
						
							|  |  |  |  |  * this.) | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_service (GResolver     *resolver, | 
					
						
							|  |  |  |  |                            const gchar   *service, | 
					
						
							|  |  |  |  |                            const gchar   *protocol, | 
					
						
							|  |  |  |  |                            const gchar   *domain, | 
					
						
							|  |  |  |  |                            GCancellable  *cancellable, | 
					
						
							|  |  |  |  |                            GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *targets; | 
					
						
							|  |  |  |  |   gchar *rrname; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (service != NULL, NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (protocol != NULL, NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (domain != NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   rrname = g_resolver_get_service_rrname (service, protocol, domain); | 
					
						
							| 
									
										
										
										
											2016-12-07 17:39:56 +01:00
										 |  |  |  |   if (!rrname) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED, | 
					
						
							|  |  |  |  |                            _("Invalid domain")); | 
					
						
							|  |  |  |  |       return NULL; | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |   targets = G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_service (resolver, rrname, cancellable, error); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_free (rrname); | 
					
						
							|  |  |  |  |   return targets; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_service_async: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @service: the service type to look up (eg, "ldap") | 
					
						
							|  |  |  |  |  * @protocol: the networking protocol to use for @service (eg, "tcp") | 
					
						
							|  |  |  |  |  * @domain: the DNS domain to look up the service in | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2023-02-20 14:43:02 -06:00
										 |  |  |  |  * @callback: (scope async) (closure user_data): callback to call after resolution completes | 
					
						
							|  |  |  |  |  * @user_data: data for @callback | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Begins asynchronously performing a DNS SRV lookup for the given | 
					
						
							|  |  |  |  |  * @service and @protocol in the given @domain, and eventually calls | 
					
						
							|  |  |  |  |  * @callback, which must call g_resolver_lookup_service_finish() to | 
					
						
							|  |  |  |  |  * get the final result. See g_resolver_lookup_service() for more | 
					
						
							|  |  |  |  |  * details. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_lookup_service_async (GResolver           *resolver, | 
					
						
							|  |  |  |  |                                  const gchar         *service, | 
					
						
							|  |  |  |  |                                  const gchar         *protocol, | 
					
						
							|  |  |  |  |                                  const gchar         *domain, | 
					
						
							|  |  |  |  |                                  GCancellable        *cancellable, | 
					
						
							|  |  |  |  |                                  GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |  |                                  gpointer             user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   gchar *rrname; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_RESOLVER (resolver)); | 
					
						
							|  |  |  |  |   g_return_if_fail (service != NULL); | 
					
						
							|  |  |  |  |   g_return_if_fail (protocol != NULL); | 
					
						
							|  |  |  |  |   g_return_if_fail (domain != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   rrname = g_resolver_get_service_rrname (service, protocol, domain); | 
					
						
							| 
									
										
										
										
											2016-12-07 17:39:56 +01:00
										 |  |  |  |   if (!rrname) | 
					
						
							|  |  |  |  |     { | 
					
						
							|  |  |  |  |       g_task_report_new_error (resolver, callback, user_data, | 
					
						
							|  |  |  |  |                                g_resolver_lookup_service_async, | 
					
						
							|  |  |  |  |                                G_IO_ERROR, G_IO_ERROR_FAILED, | 
					
						
							|  |  |  |  |                                _("Invalid domain")); | 
					
						
							|  |  |  |  |       return; | 
					
						
							|  |  |  |  |     } | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |   G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_service_async (resolver, rrname, cancellable, callback, user_data); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_free (rrname); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_service_finish: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @result: the result passed to your #GAsyncReadyCallback | 
					
						
							|  |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Retrieves the result of a previous call to | 
					
						
							|  |  |  |  |  * g_resolver_lookup_service_async(). | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution failed, @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * a value from #GResolverError. If the operation was cancelled, | 
					
						
							|  |  |  |  |  * @error will be set to %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * Returns: (element-type GSrvTarget) (transfer full): a non-empty #GList of | 
					
						
							|  |  |  |  |  * #GSrvTarget, or %NULL on error. See g_resolver_lookup_service() for more | 
					
						
							|  |  |  |  |  * details. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_service_finish (GResolver     *resolver, | 
					
						
							|  |  |  |  |                                   GAsyncResult  *result, | 
					
						
							|  |  |  |  |                                   GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-05-10 09:00:45 -04:00
										 |  |  |  |   if (g_async_result_legacy_propagate_error (result, error)) | 
					
						
							|  |  |  |  |     return NULL; | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   return G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_service_finish (resolver, result, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2010-09-24 15:51:26 -03:00
										 |  |  |  |  * g_resolver_free_targets: (skip) | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * @targets: a #GList of #GSrvTarget | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Frees @targets (which should be the return value from | 
					
						
							|  |  |  |  |  * g_resolver_lookup_service() or g_resolver_lookup_service_finish()). | 
					
						
							|  |  |  |  |  * (This is a convenience method; you can also simply free the | 
					
						
							|  |  |  |  |  * results by hand.) | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_free_targets (GList *targets) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *t; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   for (t = targets; t; t = t->next) | 
					
						
							|  |  |  |  |     g_srv_target_free (t->data); | 
					
						
							|  |  |  |  |   g_list_free (targets); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_records: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							| 
									
										
										
										
											2019-04-26 12:12:31 +01:00
										 |  |  |  |  * @rrname: the DNS name to look up the record for | 
					
						
							|  |  |  |  |  * @record_type: the type of DNS record to look up | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Synchronously performs a DNS record lookup for the given @rrname and returns | 
					
						
							|  |  |  |  |  * a list of records as #GVariant tuples. See #GResolverRecordType for | 
					
						
							|  |  |  |  |  * information on what the records contain for each @record_type. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution fails, @error (if non-%NULL) will be set to | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * a value from #GResolverError and %NULL will be returned. | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * If @cancellable is non-%NULL, it can be used to cancel the | 
					
						
							|  |  |  |  |  * operation, in which case @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * Returns: (element-type GVariant) (transfer full): a non-empty #GList of | 
					
						
							|  |  |  |  |  * #GVariant, or %NULL on error. You must free each of the records and the list | 
					
						
							|  |  |  |  |  * when you are done with it. (You can use g_list_free_full() with | 
					
						
							|  |  |  |  |  * g_variant_unref() to do this.) | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.34 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_records (GResolver            *resolver, | 
					
						
							|  |  |  |  |                            const gchar          *rrname, | 
					
						
							|  |  |  |  |                            GResolverRecordType   record_type, | 
					
						
							|  |  |  |  |                            GCancellable         *cancellable, | 
					
						
							|  |  |  |  |                            GError              **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GList *records; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  |   g_return_val_if_fail (rrname != NULL, NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |   records = G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_records (resolver, rrname, record_type, cancellable, error); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return records; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_records_async: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							| 
									
										
										
										
											2019-04-26 12:12:31 +01:00
										 |  |  |  |  * @rrname: the DNS name to look up the record for | 
					
						
							|  |  |  |  |  * @record_type: the type of DNS record to look up | 
					
						
							| 
									
										
										
										
											2016-10-28 18:29:02 -07:00
										 |  |  |  |  * @cancellable: (nullable): a #GCancellable, or %NULL | 
					
						
							| 
									
										
										
										
											2023-02-20 14:43:02 -06:00
										 |  |  |  |  * @callback: (scope async) (closure user_data): callback to call after resolution completes | 
					
						
							|  |  |  |  |  * @user_data: data for @callback | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Begins asynchronously performing a DNS lookup for the given | 
					
						
							|  |  |  |  |  * @rrname, and eventually calls @callback, which must call | 
					
						
							|  |  |  |  |  * g_resolver_lookup_records_finish() to get the final result. See | 
					
						
							|  |  |  |  |  * g_resolver_lookup_records() for more details. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.34 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_lookup_records_async (GResolver           *resolver, | 
					
						
							|  |  |  |  |                                  const gchar         *rrname, | 
					
						
							|  |  |  |  |                                  GResolverRecordType  record_type, | 
					
						
							|  |  |  |  |                                  GCancellable        *cancellable, | 
					
						
							|  |  |  |  |                                  GAsyncReadyCallback  callback, | 
					
						
							|  |  |  |  |                                  gpointer             user_data) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_RESOLVER (resolver)); | 
					
						
							|  |  |  |  |   g_return_if_fail (rrname != NULL); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |   G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_records_async (resolver, rrname, record_type, cancellable, callback, user_data); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_lookup_records_finish: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @result: the result passed to your #GAsyncReadyCallback | 
					
						
							|  |  |  |  |  * @error: return location for a #GError, or %NULL | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Retrieves the result of a previous call to | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * g_resolver_lookup_records_async(). Returns a non-empty list of records as | 
					
						
							|  |  |  |  |  * #GVariant tuples. See #GResolverRecordType for information on what the | 
					
						
							|  |  |  |  |  * records contain. | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * If the DNS resolution failed, @error (if non-%NULL) will be set to | 
					
						
							|  |  |  |  |  * a value from #GResolverError. If the operation was cancelled, | 
					
						
							|  |  |  |  |  * @error will be set to %G_IO_ERROR_CANCELLED. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-04-24 09:24:48 +01:00
										 |  |  |  |  * Returns: (element-type GVariant) (transfer full): a non-empty #GList of | 
					
						
							|  |  |  |  |  * #GVariant, or %NULL on error. You must free each of the records and the list | 
					
						
							|  |  |  |  |  * when you are done with it. (You can use g_list_free_full() with | 
					
						
							|  |  |  |  |  * g_variant_unref() to do this.) | 
					
						
							| 
									
										
										
											
												Add support for MX, TXT, NS and SOA records to GResolver
 * Add resolver functions for looking up DNS records of
   various types. Currently implemented: MX, TXT, SOA, SRV, NS
 * Return records as GVariant tuples.
 * Make the GSrvTarget lookups a wrapper over this new
   functionality.
 * Rework the resolver test so that it has support for
   looking up MX, NS, SOA, TXT records, and uses GOptionContext
https://bugzilla.gnome.org/show_bug.cgi?id=672944
											
										 
											2012-04-04 17:13:10 +02:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.34 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | GList * | 
					
						
							|  |  |  |  | g_resolver_lookup_records_finish (GResolver     *resolver, | 
					
						
							|  |  |  |  |                                   GAsyncResult  *result, | 
					
						
							|  |  |  |  |                                   GError       **error) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), NULL); | 
					
						
							|  |  |  |  |   return G_RESOLVER_GET_CLASS (resolver)-> | 
					
						
							|  |  |  |  |     lookup_records_finish (resolver, result, error); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-19 15:19:22 -05:00
										 |  |  |  | guint64 | 
					
						
							|  |  |  |  | g_resolver_get_serial (GResolver *resolver) | 
					
						
							|  |  |  |  | { | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |   guint64 result; | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-02-19 15:19:22 -05:00
										 |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:08:11 -06:00
										 |  |  |  |   maybe_emit_reload (resolver); | 
					
						
							| 
									
										
										
										
											2013-02-19 15:19:22 -05:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  | #ifdef G_OS_UNIX
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |   g_mutex_lock (&resolver->priv->mutex); | 
					
						
							|  |  |  |  |   result = resolver->priv->resolv_conf_timestamp; | 
					
						
							|  |  |  |  |   g_mutex_unlock (&resolver->priv->mutex); | 
					
						
							| 
									
										
										
										
											2013-02-19 15:19:22 -05:00
										 |  |  |  | #else
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  |   result = 1; | 
					
						
							| 
									
										
										
										
											2013-02-19 15:19:22 -05:00
										 |  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2021-11-22 15:20:18 -06:00
										 |  |  |  | 
 | 
					
						
							|  |  |  |  |   return result; | 
					
						
							| 
									
										
										
										
											2013-02-19 15:19:22 -05:00
										 |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_get_timeout: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Get the timeout applied to all resolver lookups. See #GResolver:timeout. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Returns: the resolver timeout, in milliseconds, or `0` for no timeout | 
					
						
							| 
									
										
										
										
											2023-06-04 17:32:29 +02:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2023-03-29 17:13:49 +01:00
										 |  |  |  |  * Since: 2.78 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | unsigned | 
					
						
							|  |  |  |  | g_resolver_get_timeout (GResolver *resolver) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GResolverPrivate *priv = g_resolver_get_instance_private (resolver); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_val_if_fail (G_IS_RESOLVER (resolver), 0); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   return priv->timeout_ms; | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_set_timeout: | 
					
						
							|  |  |  |  |  * @resolver: a #GResolver | 
					
						
							|  |  |  |  |  * @timeout_ms: timeout in milliseconds, or `0` for no timeouts | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Set the timeout applied to all resolver lookups. See #GResolver:timeout. | 
					
						
							|  |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.78 | 
					
						
							|  |  |  |  |  */ | 
					
						
							|  |  |  |  | void | 
					
						
							|  |  |  |  | g_resolver_set_timeout (GResolver *resolver, | 
					
						
							|  |  |  |  |                         unsigned   timeout_ms) | 
					
						
							|  |  |  |  | { | 
					
						
							|  |  |  |  |   GResolverPrivate *priv = g_resolver_get_instance_private (resolver); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   g_return_if_fail (G_IS_RESOLVER (resolver)); | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   if (priv->timeout_ms == timeout_ms) | 
					
						
							|  |  |  |  |     return; | 
					
						
							|  |  |  |  | 
 | 
					
						
							|  |  |  |  |   priv->timeout_ms = timeout_ms; | 
					
						
							|  |  |  |  |   g_object_notify_by_pspec (G_OBJECT (resolver), props[PROP_TIMEOUT]); | 
					
						
							|  |  |  |  | } | 
					
						
							|  |  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  | /**
 | 
					
						
							|  |  |  |  |  * g_resolver_error_quark: | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * Gets the #GResolver Error Quark. | 
					
						
							|  |  |  |  |  * | 
					
						
							| 
									
										
										
										
											2014-02-19 19:35:23 -05:00
										 |  |  |  |  * Returns: a #GQuark. | 
					
						
							| 
									
										
										
										
											2008-12-29 12:53:47 -05:00
										 |  |  |  |  * | 
					
						
							|  |  |  |  |  * Since: 2.22 | 
					
						
							| 
									
										
										
										
											2009-05-03 18:04:31 -04:00
										 |  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2012-08-28 13:15:29 -04:00
										 |  |  |  | G_DEFINE_QUARK (g-resolver-error-quark, g_resolver_error) |