|
|
75a7a3 |
From 1dc72abeb4419027f649d67fd95b302c8233335d Mon Sep 17 00:00:00 2001
|
|
|
75a7a3 |
From: Ray Strode <rstrode@redhat.com>
|
|
|
75a7a3 |
Date: Fri, 31 Mar 2017 14:59:05 -0400
|
|
|
75a7a3 |
Subject: [PATCH 09/13] xdmcp-display-factory: explicitly stop greeter session
|
|
|
75a7a3 |
on disconnect
|
|
|
75a7a3 |
|
|
|
75a7a3 |
If the client disconnects, we should kill off the necessary processes.
|
|
|
75a7a3 |
---
|
|
|
75a7a3 |
daemon/gdm-xdmcp-display-factory.c | 1 +
|
|
|
75a7a3 |
1 file changed, 1 insertion(+)
|
|
|
75a7a3 |
|
|
|
75a7a3 |
diff --git a/daemon/gdm-xdmcp-display-factory.c b/daemon/gdm-xdmcp-display-factory.c
|
|
|
75a7a3 |
index c5f7ddb4..3a8506ce 100644
|
|
|
75a7a3 |
--- a/daemon/gdm-xdmcp-display-factory.c
|
|
|
75a7a3 |
+++ b/daemon/gdm-xdmcp-display-factory.c
|
|
|
75a7a3 |
@@ -2029,60 +2029,61 @@ on_hostname_selected (GdmXdmcpChooserDisplay *display,
|
|
|
75a7a3 |
g_warning ("Unable to get address: %s", gai_strerror (gaierr));
|
|
|
75a7a3 |
g_free (xdmcp_port);
|
|
|
75a7a3 |
return;
|
|
|
75a7a3 |
}
|
|
|
75a7a3 |
g_free (xdmcp_port);
|
|
|
75a7a3 |
|
|
|
75a7a3 |
/* just take the first one */
|
|
|
75a7a3 |
ai = ai_list;
|
|
|
75a7a3 |
|
|
|
75a7a3 |
if (ai != NULL) {
|
|
|
75a7a3 |
char *ip;
|
|
|
75a7a3 |
ic->chosen_address = gdm_address_new_from_sockaddr (ai->ai_addr, ai->ai_addrlen);
|
|
|
75a7a3 |
|
|
|
75a7a3 |
ip = NULL;
|
|
|
75a7a3 |
gdm_address_get_numeric_info (ic->chosen_address, &ip, NULL);
|
|
|
75a7a3 |
g_debug ("GdmXdmcpDisplayFactory: hostname resolves to %s",
|
|
|
75a7a3 |
ip ? ip : "(null)");
|
|
|
75a7a3 |
g_free (ip);
|
|
|
75a7a3 |
}
|
|
|
75a7a3 |
|
|
|
75a7a3 |
freeaddrinfo (ai_list);
|
|
|
75a7a3 |
}
|
|
|
75a7a3 |
|
|
|
75a7a3 |
static void
|
|
|
75a7a3 |
on_client_disconnected (GdmSession *session,
|
|
|
75a7a3 |
GdmDisplay *display)
|
|
|
75a7a3 |
{
|
|
|
75a7a3 |
if (gdm_display_get_status (display) != GDM_DISPLAY_MANAGED)
|
|
|
75a7a3 |
return;
|
|
|
75a7a3 |
|
|
|
75a7a3 |
+ gdm_display_stop_greeter_session (display);
|
|
|
75a7a3 |
gdm_display_unmanage (display);
|
|
|
75a7a3 |
gdm_display_finish (display);
|
|
|
75a7a3 |
}
|
|
|
75a7a3 |
|
|
|
75a7a3 |
static void
|
|
|
75a7a3 |
on_display_status_changed (GdmDisplay *display,
|
|
|
75a7a3 |
GParamSpec *arg1,
|
|
|
75a7a3 |
GdmXdmcpDisplayFactory *factory)
|
|
|
75a7a3 |
{
|
|
|
75a7a3 |
int status;
|
|
|
75a7a3 |
GdmDisplayStore *store;
|
|
|
75a7a3 |
GdmLaunchEnvironment *launch_environment;
|
|
|
75a7a3 |
GdmSession *session;
|
|
|
75a7a3 |
GdmAddress *address;
|
|
|
75a7a3 |
gint32 session_number;
|
|
|
75a7a3 |
int display_number;
|
|
|
75a7a3 |
|
|
|
75a7a3 |
store = gdm_display_factory_get_display_store (GDM_DISPLAY_FACTORY (factory));
|
|
|
75a7a3 |
|
|
|
75a7a3 |
launch_environment = NULL;
|
|
|
75a7a3 |
g_object_get (display, "launch-environment", &launch_environment, NULL);
|
|
|
75a7a3 |
|
|
|
75a7a3 |
session = NULL;
|
|
|
75a7a3 |
if (launch_environment != NULL) {
|
|
|
75a7a3 |
session = gdm_launch_environment_get_session (launch_environment);
|
|
|
75a7a3 |
}
|
|
|
75a7a3 |
|
|
|
75a7a3 |
status = gdm_display_get_status (display);
|
|
|
75a7a3 |
|
|
|
75a7a3 |
g_debug ("GdmXdmcpDisplayFactory: xdmcp display status changed: %d", status);
|
|
|
75a7a3 |
--
|
|
|
75a7a3 |
2.12.0
|
|
|
75a7a3 |
|