summaryrefslogtreecommitdiff
path: root/src/seat-unity.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/seat-unity.c')
-rw-r--r--src/seat-unity.c422
1 files changed, 0 insertions, 422 deletions
diff --git a/src/seat-unity.c b/src/seat-unity.c
deleted file mode 100644
index 649c94d1..00000000
--- a/src/seat-unity.c
+++ /dev/null
@@ -1,422 +0,0 @@
-/*
- * Copyright (C) 2012-2013 Robert Ancell.
- * Author: Robert Ancell <robert.ancell@canonical.com>
- *
- * This program is free software: you can redistribute it and/or modify it under
- * the terms of the GNU General Public License as published by the Free Software
- * Foundation, either version 3 of the License, or (at your option) any later
- * version. See http://www.gnu.org/copyleft/gpl.html the full text of the
- * license.
- */
-
-#include <string.h>
-#include <fcntl.h>
-#include <errno.h>
-#include <glib/gstdio.h>
-
-#include "seat-unity.h"
-#include "configuration.h"
-#include "unity-system-compositor.h"
-#include "x-server-xmir.h"
-#include "vt.h"
-#include "plymouth.h"
-
-typedef struct
-{
- /* System compositor */
- UnitySystemCompositor *compositor;
-
- /* X server being used for XDMCP */
- XServerXmir *xdmcp_x_server;
-
- /* Next Mir ID to use for a Xmir servers */
- gint next_x_server_id;
-
- /* The currently visible session */
- Session *active_session;
- DisplayServer *active_display_server;
-} SeatUnityPrivate;
-
-G_DEFINE_TYPE_WITH_PRIVATE (SeatUnity, seat_unity, SEAT_TYPE)
-
-static XServerXmir *create_x_server (Seat *seat);
-
-static void
-seat_unity_setup (Seat *seat)
-{
- seat_set_supports_multi_session (seat, TRUE);
- SEAT_CLASS (seat_unity_parent_class)->setup (seat);
-}
-
-static void
-check_stopped (SeatUnity *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (seat);
- if (!priv->compositor && !priv->xdmcp_x_server)
- SEAT_CLASS (seat_unity_parent_class)->stop (SEAT (seat));
-}
-
-static void
-xdmcp_x_server_stopped_cb (DisplayServer *display_server, Seat *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- l_debug (seat, "XDMCP X server stopped");
-
- g_signal_handlers_disconnect_matched (priv->xdmcp_x_server, G_SIGNAL_MATCH_DATA, 0, 0, NULL, NULL, seat);
- priv->xdmcp_x_server = NULL;
-
- g_object_unref (display_server);
-
- if (seat_get_is_stopping (seat))
- check_stopped (SEAT_UNITY (seat));
- else
- seat_stop (seat);
-}
-
-static void
-compositor_ready_cb (UnitySystemCompositor *compositor, SeatUnity *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (seat);
-
- l_debug (seat, "Compositor ready");
-
- /* If running as an XDMCP client then just start an X server */
- const gchar *xdmcp_manager = seat_get_string_property (SEAT (seat), "xdmcp-manager");
- if (xdmcp_manager)
- {
- priv->xdmcp_x_server = create_x_server (SEAT (seat));
- x_server_local_set_xdmcp_server (X_SERVER_LOCAL (priv->xdmcp_x_server), xdmcp_manager);
- gint port = seat_get_integer_property (SEAT (seat), "xdmcp-port");
- if (port > 0)
- x_server_local_set_xdmcp_port (X_SERVER_LOCAL (priv->xdmcp_x_server), port);
- const gchar *key_name = seat_get_string_property (SEAT (seat), "xdmcp-key");
- if (key_name)
- {
- g_autofree gchar *path = g_build_filename (config_get_directory (config_get_instance ()), "keys.conf", NULL);
-
- g_autoptr(GKeyFile) keys = g_key_file_new ();
- g_autoptr(GError) error = NULL;
- gboolean result = g_key_file_load_from_file (keys, path, G_KEY_FILE_NONE, &error);
- if (error)
- l_debug (seat, "Error getting key %s", error->message);
-
- if (result)
- {
- if (g_key_file_has_key (keys, "keyring", key_name, NULL))
- {
- g_autofree gchar *key = g_key_file_get_string (keys, "keyring", key_name, NULL);
- if (key)
- x_server_local_set_xdmcp_key (X_SERVER_LOCAL (priv->xdmcp_x_server), key);
- }
- else
- l_debug (seat, "Key %s not defined", key_name);
- }
- }
-
- g_signal_connect (priv->xdmcp_x_server, DISPLAY_SERVER_SIGNAL_STOPPED, G_CALLBACK (xdmcp_x_server_stopped_cb), seat);
- if (!display_server_start (DISPLAY_SERVER (priv->xdmcp_x_server)))
- seat_stop (SEAT (seat));
- }
-
- SEAT_CLASS (seat_unity_parent_class)->start (SEAT (seat));
-}
-
-static void
-compositor_stopped_cb (UnitySystemCompositor *compositor, SeatUnity *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (seat);
-
- l_debug (seat, "Compositor stopped");
-
- g_clear_object (&priv->compositor);
-
- if (seat_get_is_stopping (SEAT (seat)))
- check_stopped (seat);
- else
- seat_stop (SEAT (seat));
-}
-
-static gboolean
-seat_unity_start (Seat *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- /* Replace Plymouth if it is running */
- gint vt = -1;
- if (plymouth_get_is_active () && plymouth_has_active_vt ())
- {
- gint active_vt = vt_get_active ();
- if (active_vt >= vt_get_min ())
- {
- vt = active_vt;
- plymouth_quit (TRUE);
- }
- else
- l_debug (seat, "Plymouth is running on VT %d, but this is less than the configured minimum of %d so not replacing it", active_vt, vt_get_min ());
- }
- if (plymouth_get_is_active ())
- plymouth_quit (FALSE);
- if (vt < 0)
- vt = vt_can_multi_seat () ? vt_get_unused () : 0;
- if (vt < 0)
- {
- l_debug (seat, "Failed to get a VT to run on");
- return FALSE;
- }
-
- int timeout = seat_get_integer_property (SEAT (seat), "unity-compositor-timeout");
- if (timeout <= 0)
- timeout = 60;
-
- priv->compositor = unity_system_compositor_new ();
- g_signal_connect (priv->compositor, DISPLAY_SERVER_SIGNAL_READY, G_CALLBACK (compositor_ready_cb), seat);
- g_signal_connect (priv->compositor, DISPLAY_SERVER_SIGNAL_STOPPED, G_CALLBACK (compositor_stopped_cb), seat);
- unity_system_compositor_set_command (priv->compositor, seat_get_string_property (SEAT (seat), "unity-compositor-command"));
- unity_system_compositor_set_vt (priv->compositor, vt);
- unity_system_compositor_set_timeout (priv->compositor, timeout);
-
- return display_server_start (DISPLAY_SERVER (priv->compositor));
-}
-
-static XServerXmir *
-create_x_server (Seat *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- l_debug (seat, "Starting X server on Unity compositor");
-
- g_autoptr(XServerXmir) x_server = x_server_xmir_new (priv->compositor);
-
- const gchar *command = seat_get_string_property (seat, "xmir-command");
- x_server_local_set_command (X_SERVER_LOCAL (x_server), command);
-
- g_autofree gchar *id = g_strdup_printf ("x-%d", priv->next_x_server_id);
- priv->next_x_server_id++;
- x_server_xmir_set_mir_id (x_server, id);
- x_server_xmir_set_mir_socket (x_server, unity_system_compositor_get_socket (priv->compositor));
-
- g_autofree gchar *number = g_strdup_printf ("%d", x_server_get_display_number (X_SERVER (x_server)));
- g_autoptr(XAuthority) cookie = x_authority_new_local_cookie (number);
- x_server_set_authority (X_SERVER (x_server), cookie);
-
- const gchar *layout = seat_get_string_property (seat, "xserver-layout");
- if (layout)
- x_server_local_set_layout (X_SERVER_LOCAL (x_server), layout);
-
- x_server_local_set_xdg_seat (X_SERVER_LOCAL (x_server), seat_get_name (seat));
-
- const gchar *config_file = seat_get_string_property (seat, "xserver-config");
- if (config_file)
- x_server_local_set_config (X_SERVER_LOCAL (x_server), config_file);
-
- gboolean allow_tcp = seat_get_boolean_property (seat, "xserver-allow-tcp");
- x_server_local_set_allow_tcp (X_SERVER_LOCAL (x_server), allow_tcp);
-
- return g_steal_pointer (&x_server);
-}
-
-static DisplayServer *
-seat_unity_create_display_server (Seat *seat, Session *session)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- const gchar *session_type = session_get_session_type (session);
- if (strcmp (session_type, "x") == 0)
- return DISPLAY_SERVER (create_x_server (seat));
- else if (strcmp (session_type, "mir") == 0)
- return g_object_ref (DISPLAY_SERVER (priv->compositor));
- else
- {
- l_warning (seat, "Can't create unsupported display server '%s'", session_type);
- return NULL;
- }
-}
-
-static gboolean
-seat_unity_display_server_is_used (Seat *seat, DisplayServer *display_server)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- if (display_server == DISPLAY_SERVER (priv->compositor))
- return TRUE;
-
- return SEAT_CLASS (seat_unity_parent_class)->display_server_is_used (seat, display_server);
-}
-
-static GreeterSession *
-seat_unity_create_greeter_session (Seat *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- GreeterSession *greeter_session = SEAT_CLASS (seat_unity_parent_class)->create_greeter_session (seat);
- session_set_env (SESSION (greeter_session), "XDG_SEAT", seat_get_name (seat));
-
- gint vt = display_server_get_vt (DISPLAY_SERVER (priv->compositor));
- if (vt >= 0)
- {
- g_autofree gchar *value = g_strdup_printf ("%d", vt);
- session_set_env (SESSION (greeter_session), "XDG_VTNR", value);
- }
-
- return greeter_session;
-}
-
-static Session *
-seat_unity_create_session (Seat *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- Session *session = SEAT_CLASS (seat_unity_parent_class)->create_session (seat);
- session_set_env (session, "XDG_SEAT", seat_get_name (seat));
-
- gint vt = display_server_get_vt (DISPLAY_SERVER (priv->compositor));
- if (vt >= 0)
- {
- g_autofree gchar *value = g_strdup_printf ("%d", vt);
- session_set_env (SESSION (session), "XDG_VTNR", value);
- }
-
- return session;
-}
-
-static const gchar *
-get_mir_id (Session *session)
-{
- if (!session)
- return NULL;
-
- DisplayServer *display_server = session_get_display_server (session);
- if (IS_UNITY_SYSTEM_COMPOSITOR (display_server))
- return session_get_env (session, "MIR_SERVER_NAME");
- if (IS_X_SERVER_XMIR (display_server))
- return x_server_xmir_get_mir_id (X_SERVER_XMIR (display_server));
-
- return NULL;
-}
-
-static void
-seat_unity_set_active_session (Seat *seat, Session *session)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- const gchar *old_id = get_mir_id (priv->active_session);
- const gchar *new_id = get_mir_id (session);
-
- g_clear_object (&priv->active_session);
- priv->active_session = g_object_ref (session);
-
- if (g_strcmp0 (old_id, new_id) != 0)
- unity_system_compositor_set_active_session (priv->compositor, new_id);
-
- SEAT_CLASS (seat_unity_parent_class)->set_active_session (seat, session);
-}
-
-static Session *
-seat_unity_get_active_session (Seat *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
- return priv->active_session;
-}
-
-static void
-seat_unity_set_next_session (Seat *seat, Session *session)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- if (!session)
- return;
-
- DisplayServer *display_server = session_get_display_server (session);
-
- const gchar *id = NULL;
- if (IS_X_SERVER_LOCAL (display_server))
- id = x_server_xmir_get_mir_id (X_SERVER_XMIR (display_server));
- else
- id = session_get_env (session, "MIR_SERVER_NAME");
-
- if (id)
- {
- l_debug (seat, "Marking Mir session %s as the next session", id);
- unity_system_compositor_set_next_session (priv->compositor, id);
- }
- else
- {
- l_debug (seat, "Failed to work out session ID to mark");
- }
-
- SEAT_CLASS (seat_unity_parent_class)->set_next_session (seat, session);
-}
-
-static void
-seat_unity_run_script (Seat *seat, DisplayServer *display_server, Process *script)
-{
- if (IS_X_SERVER_XMIR (display_server))
- {
- XServerXmir *x_server = X_SERVER_XMIR (display_server);
- const gchar *path = x_server_local_get_authority_file_path (X_SERVER_LOCAL (x_server));
- process_set_env (script, "DISPLAY", x_server_get_address (X_SERVER (x_server)));
- process_set_env (script, "XAUTHORITY", path);
- }
-
- SEAT_CLASS (seat_unity_parent_class)->run_script (seat, display_server, script);
-}
-
-static void
-seat_unity_stop (Seat *seat)
-{
- SeatUnityPrivate *priv = seat_unity_get_instance_private (SEAT_UNITY (seat));
-
- /* Stop the compositor first */
- if (priv->compositor)
- display_server_stop (DISPLAY_SERVER (priv->compositor));
-
- /* Stop the XDMCP X server first */
- if (priv->xdmcp_x_server)
- display_server_stop (DISPLAY_SERVER (priv->xdmcp_x_server));
-
- check_stopped (SEAT_UNITY (seat));
-}
-
-static void
-seat_unity_init (SeatUnity *seat)
-{
-}
-
-static void
-seat_unity_finalize (GObject *object)
-{
- SeatUnity *seat = SEAT_UNITY (object);
- SeatUnityPrivate *priv = seat_unity_get_instance_private (seat);
-
- g_clear_object (&priv->compositor);
- if (priv->xdmcp_x_server)
- {
- g_signal_handlers_disconnect_matched (priv->xdmcp_x_server, G_SIGNAL_MATCH_DATA, 0, 0, NULL, NULL, seat);
- g_object_unref (priv->xdmcp_x_server);
- }
- g_clear_object (&priv->active_session);
- g_clear_object (&priv->active_display_server);
-
- G_OBJECT_CLASS (seat_unity_parent_class)->finalize (object);
-}
-
-static void
-seat_unity_class_init (SeatUnityClass *klass)
-{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
- SeatClass *seat_class = SEAT_CLASS (klass);
-
- object_class->finalize = seat_unity_finalize;
- seat_class->setup = seat_unity_setup;
- seat_class->start = seat_unity_start;
- seat_class->create_display_server = seat_unity_create_display_server;
- seat_class->display_server_is_used = seat_unity_display_server_is_used;
- seat_class->create_greeter_session = seat_unity_create_greeter_session;
- seat_class->create_session = seat_unity_create_session;
- seat_class->set_active_session = seat_unity_set_active_session;
- seat_class->get_active_session = seat_unity_get_active_session;
- seat_class->set_next_session = seat_unity_set_next_session;
- seat_class->run_script = seat_unity_run_script;
- seat_class->stop = seat_unity_stop;
-}