mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-13 07:56:17 +01:00
Merge branch 'gdbus-server-no-abstract-tmpdir' into 'main'
Fix sandbox escape in GDBusServer See merge request GNOME/glib!3005
This commit is contained in:
commit
d83c87c1f6
@ -1618,13 +1618,8 @@ initable_init (GInitable *initable,
|
||||
if (daemon->address == NULL)
|
||||
{
|
||||
#ifdef G_OS_UNIX
|
||||
if (g_unix_socket_address_abstract_names_supported ())
|
||||
daemon->address = g_strdup ("unix:tmpdir=/tmp/gdbus-daemon");
|
||||
else
|
||||
{
|
||||
daemon->tmpdir = g_dir_make_tmp ("gdbus-daemon-XXXXXX", NULL);
|
||||
daemon->address = g_strdup_printf ("unix:tmpdir=%s", daemon->tmpdir);
|
||||
}
|
||||
daemon->tmpdir = g_dir_make_tmp ("gdbus-daemon-XXXXXX", NULL);
|
||||
daemon->address = g_strdup_printf ("unix:tmpdir=%s", daemon->tmpdir);
|
||||
flags |= G_DBUS_SERVER_FLAGS_AUTHENTICATION_REQUIRE_SAME_USER;
|
||||
#else
|
||||
/* Don’t require authentication on Windows as that hasn’t been
|
||||
|
@ -725,14 +725,7 @@ try_unix (GDBusServer *server,
|
||||
for (n = 0; n < 8; n++)
|
||||
g_string_append_c (s, random_ascii ());
|
||||
|
||||
/* prefer abstract namespace if available for tmpdir: addresses
|
||||
* abstract namespace is disallowed for dir: addresses */
|
||||
if (tmpdir != NULL && g_unix_socket_address_abstract_names_supported ())
|
||||
address = g_unix_socket_address_new_with_type (s->str,
|
||||
-1,
|
||||
G_UNIX_SOCKET_ADDRESS_ABSTRACT);
|
||||
else
|
||||
address = g_unix_socket_address_new (s->str);
|
||||
address = g_unix_socket_address_new (s->str);
|
||||
g_string_free (s, TRUE);
|
||||
|
||||
local_error = NULL;
|
||||
|
@ -63,17 +63,10 @@ server_new_for_mechanism (const gchar *allowed_mechanism)
|
||||
guid = g_dbus_generate_guid ();
|
||||
|
||||
#ifdef G_OS_UNIX
|
||||
if (g_unix_socket_address_abstract_names_supported ())
|
||||
{
|
||||
addr = g_strdup ("unix:tmpdir=/tmp/gdbus-test-");
|
||||
}
|
||||
else
|
||||
{
|
||||
gchar *tmpdir;
|
||||
tmpdir = g_dir_make_tmp ("gdbus-test-XXXXXX", NULL);
|
||||
addr = g_strdup_printf ("unix:tmpdir=%s", tmpdir);
|
||||
g_free (tmpdir);
|
||||
}
|
||||
gchar *tmpdir;
|
||||
tmpdir = g_dir_make_tmp ("gdbus-test-XXXXXX", NULL);
|
||||
addr = g_strdup_printf ("unix:tmpdir=%s", tmpdir);
|
||||
g_free (tmpdir);
|
||||
#else
|
||||
addr = g_strdup ("nonce-tcp:");
|
||||
#endif
|
||||
|
@ -219,13 +219,8 @@ main (int argc,
|
||||
|
||||
if (is_unix)
|
||||
{
|
||||
if (g_unix_socket_address_abstract_names_supported ())
|
||||
tmp_address = g_strdup ("unix:tmpdir=/tmp/gdbus-test-");
|
||||
else
|
||||
{
|
||||
tmpdir = g_dir_make_tmp ("gdbus-test-XXXXXX", NULL);
|
||||
tmp_address = g_strdup_printf ("unix:tmpdir=%s", tmpdir);
|
||||
}
|
||||
tmpdir = g_dir_make_tmp ("gdbus-test-XXXXXX", NULL);
|
||||
tmp_address = g_strdup_printf ("unix:tmpdir=%s", tmpdir);
|
||||
}
|
||||
else
|
||||
tmp_address = g_strdup ("nonce-tcp:");
|
||||
|
@ -831,13 +831,8 @@ service_thread_func (gpointer user_data)
|
||||
flags = G_DBUS_SERVER_FLAGS_NONE;
|
||||
|
||||
#ifdef G_OS_UNIX
|
||||
if (g_unix_socket_address_abstract_names_supported ())
|
||||
address = g_strdup ("unix:tmpdir=/tmp/test-dbus-peer");
|
||||
else
|
||||
{
|
||||
tmpdir = g_dir_make_tmp ("test-dbus-peer-XXXXXX", NULL);
|
||||
address = g_strdup_printf ("unix:tmpdir=%s", tmpdir);
|
||||
}
|
||||
tmpdir = g_dir_make_tmp ("test-dbus-peer-XXXXXX", NULL);
|
||||
address = g_strdup_printf ("unix:tmpdir=%s", tmpdir);
|
||||
#else
|
||||
address = g_strdup ("nonce-tcp:");
|
||||
flags |= G_DBUS_SERVER_FLAGS_AUTHENTICATION_ALLOW_ANONYMOUS;
|
||||
|
Loading…
Reference in New Issue
Block a user