[glib/portal: 12/17] proxy: Redo the network availability check
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [glib/portal: 12/17] proxy: Redo the network availability check
- Date: Sun, 3 Jul 2016 22:04:20 +0000 (UTC)
commit 4f6d25ed444367d8d2cffae0817d2a31769e28a5
Author: Matthias Clasen <mclasen redhat com>
Date: Thu Jun 23 10:27:50 2016 -0400
proxy: Redo the network availability check
Do this more like for the network monitor: We keep using the
portal proxy, but we neuter all results. Eventually, we can
do this on the portal side, but we need some systemd infrastructure
for it.
gio/gproxyresolverportal.c | 21 ++++++++++++++++++---
1 files changed, 18 insertions(+), 3 deletions(-)
---
diff --git a/gio/gproxyresolverportal.c b/gio/gproxyresolverportal.c
index e2c3caa..bfa74ea 100644
--- a/gio/gproxyresolverportal.c
+++ b/gio/gproxyresolverportal.c
@@ -28,6 +28,7 @@ struct _GProxyResolverPortal {
GObject parent_instance;
XdpProxyResolver *resolver;
+ gboolean network_available;
};
static void g_proxy_resolver_portal_iface_init (GProxyResolverInterface *iface);
@@ -50,6 +51,8 @@ g_proxy_resolver_portal_init (GProxyResolverPortal *resolver)
"/org/freedesktop/portal/desktop",
NULL,
NULL);
+
+ resolver->network_available = glib_network_available_in_sandbox ();
}
static gboolean
@@ -59,9 +62,7 @@ g_proxy_resolver_portal_is_supported (GProxyResolver *object)
char *name_owner;
gboolean has_portal;
- if (!glib_should_use_portal () ||
- !glib_network_available_in_sandbox () ||
- !resolver->resolver)
+ if (!glib_should_use_portal () || !resolver->resolver)
return FALSE;
name_owner = g_dbus_proxy_get_name_owner (G_DBUS_PROXY (resolver->resolver));
@@ -71,6 +72,8 @@ g_proxy_resolver_portal_is_supported (GProxyResolver *object)
return has_portal;
}
+static const char *no_proxy[2] = { "direct://", NULL };
+
static gchar **
g_proxy_resolver_portal_lookup (GProxyResolver *proxy_resolver,
const gchar *uri,
@@ -87,6 +90,12 @@ g_proxy_resolver_portal_lookup (GProxyResolver *proxy_resolver,
error))
return NULL;
+ if (!resolver->network_available)
+ {
+ g_strfreev ((gchar **)proxy);
+ proxy = g_strdupv ((gchar **)no_proxy);
+ }
+
return proxy;
}
@@ -120,6 +129,12 @@ g_proxy_resolver_portal_lookup_finish (GProxyResolver *proxy_resolver,
error))
return NULL;
+ if (!resolver->network_available)
+ {
+ g_strfreev ((gchar **)proxy);
+ proxy = g_strdupv ((gchar **)no_proxy);
+ }
+
return proxy;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]