diff options
author | Ray Strode <rstrode@redhat.com> | 2015-06-12 13:28:01 -0400 |
---|---|---|
committer | Ray Strode <rstrode@redhat.com> | 2015-06-12 14:29:03 -0400 |
commit | 1ac67f522f5690c27023d98096ca817f12f7eb88 (patch) | |
tree | 3d562e9ec0ef2ee4822bcd6888c063c5bc92b74f /common | |
parent | 9f96354ba6612f14eade901db0b95cae050d2ab9 (diff) | |
download | gdm-1ac67f522f5690c27023d98096ca817f12f7eb88.tar.gz |
drop consolekit support
It was deprecated in 3.16 to be removed in 3.18
https://bugzilla.gnome.org/show_bug.cgi?id=743940
Diffstat (limited to 'common')
-rw-r--r-- | common/gdm-common.c | 304 |
1 files changed, 0 insertions, 304 deletions
diff --git a/common/gdm-common.c b/common/gdm-common.c index effd4bc7..b4f98f1d 100644 --- a/common/gdm-common.c +++ b/common/gdm-common.c @@ -47,17 +47,6 @@ #define GDM_DBUS_LOCAL_DISPLAY_FACTORY_PATH "/org/gnome/DisplayManager/LocalDisplayFactory" #define GDM_DBUS_LOCAL_DISPLAY_FACTORY_INTERFACE "org.gnome.DisplayManager.LocalDisplayFactory" -#ifdef WITH_CONSOLE_KIT -#define CK_NAME "org.freedesktop.ConsoleKit" -#define CK_PATH "/org/freedesktop/ConsoleKit" -#define CK_INTERFACE "org.freedesktop.ConsoleKit" - -#define CK_MANAGER_PATH "/org/freedesktop/ConsoleKit/Manager" -#define CK_MANAGER_INTERFACE "org.freedesktop.ConsoleKit.Manager" -#define CK_SEAT_INTERFACE "org.freedesktop.ConsoleKit.Seat" -#define CK_SESSION_INTERFACE "org.freedesktop.ConsoleKit.Session" -#endif - G_DEFINE_QUARK (gdm-common-error, gdm_common_error); const char * @@ -356,295 +345,6 @@ create_transient_display (GDBusConnection *connection, return TRUE; } -#ifdef WITH_CONSOLE_KIT - -static gboolean -get_current_session_id (GDBusConnection *connection, - char **session_id) -{ - GError *local_error = NULL; - GVariant *reply; - - reply = g_dbus_connection_call_sync (connection, - CK_NAME, - CK_MANAGER_PATH, - CK_MANAGER_INTERFACE, - "GetCurrentSession", - NULL, /* parameters */ - G_VARIANT_TYPE ("(o)"), - G_DBUS_CALL_FLAGS_NONE, - -1, - NULL, &local_error); - if (reply == NULL) { - g_warning ("Unable to determine session: %s", local_error->message); - g_error_free (local_error); - return FALSE; - } - - g_variant_get (reply, "(o)", session_id); - g_variant_unref (reply); - - return TRUE; -} - -static gboolean -get_seat_id_for_session (GDBusConnection *connection, - const char *session_id, - char **seat_id) -{ - GError *local_error = NULL; - GVariant *reply; - - reply = g_dbus_connection_call_sync (connection, - CK_NAME, - session_id, - CK_SESSION_INTERFACE, - "GetSeatId", - NULL, /* parameters */ - G_VARIANT_TYPE ("(o)"), - G_DBUS_CALL_FLAGS_NONE, - -1, - NULL, &local_error); - if (reply == NULL) { - g_warning ("Unable to determine seat: %s", local_error->message); - g_error_free (local_error); - return FALSE; - } - - g_variant_get (reply, "(o)", seat_id); - g_variant_unref (reply); - - return TRUE; -} - -static char * -get_current_seat_id (GDBusConnection *connection) -{ - gboolean res; - char *session_id; - char *seat_id; - - session_id = NULL; - seat_id = NULL; - - res = get_current_session_id (connection, &session_id); - if (res) { - res = get_seat_id_for_session (connection, session_id, &seat_id); - } - g_free (session_id); - - return seat_id; -} - -static gboolean -activate_session_id_for_ck (GDBusConnection *connection, - const char *seat_id, - const char *session_id) -{ - GError *local_error = NULL; - GVariant *reply; - - reply = g_dbus_connection_call_sync (connection, - CK_NAME, - seat_id, - CK_SEAT_INTERFACE, - "ActivateSession", - g_variant_new ("(o)", session_id), - NULL, - G_DBUS_CALL_FLAGS_NONE, - -1, - NULL, &local_error); - if (reply == NULL) { - g_warning ("Unable to activate session: %s", local_error->message); - g_error_free (local_error); - return FALSE; - } - - g_variant_unref (reply); - - return TRUE; -} - -static gboolean -session_is_login_window (GDBusConnection *connection, - const char *session_id) -{ - GError *local_error = NULL; - GVariant *reply; - const char *value; - gboolean ret; - - reply = g_dbus_connection_call_sync (connection, - CK_NAME, - session_id, - CK_SESSION_INTERFACE, - "GetSessionType", - NULL, - G_VARIANT_TYPE ("(s)"), - G_DBUS_CALL_FLAGS_NONE, - -1, - NULL, &local_error); - if (reply == NULL) { - g_warning ("Unable to determine session type: %s", local_error->message); - g_error_free (local_error); - return FALSE; - } - - g_variant_get (reply, "(&s)", &value); - - if (value == NULL || value[0] == '\0' || strcmp (value, "LoginWindow") != 0) { - ret = FALSE; - } else { - ret = TRUE; - } - - g_variant_unref (reply); - - return ret; -} - -static gboolean -seat_can_activate_sessions (GDBusConnection *connection, - const char *seat_id) -{ - GError *local_error = NULL; - GVariant *reply; - gboolean ret; - - reply = g_dbus_connection_call_sync (connection, - CK_NAME, - seat_id, - CK_SEAT_INTERFACE, - "CanActivateSessions", - NULL, - G_VARIANT_TYPE ("(b)"), - G_DBUS_CALL_FLAGS_NONE, - -1, - NULL, &local_error); - if (reply == NULL) { - g_warning ("Unable to determine if can activate sessions: %s", local_error->message); - g_error_free (local_error); - return FALSE; - } - - g_variant_get (reply, "(b)", &ret); - g_variant_unref (reply); - - return ret; -} - -static const char ** -seat_get_sessions (GDBusConnection *connection, - const char *seat_id) -{ - GError *local_error = NULL; - GVariant *reply; - const char **value; - - reply = g_dbus_connection_call_sync (connection, - CK_NAME, - seat_id, - CK_SEAT_INTERFACE, - "GetSessions", - NULL, - G_VARIANT_TYPE ("(ao)"), - G_DBUS_CALL_FLAGS_NONE, - -1, - NULL, &local_error); - if (reply == NULL) { - g_warning ("Unable to list sessions: %s", local_error->message); - g_error_free (local_error); - return FALSE; - } - - g_variant_get (reply, "(^ao)", &value); - g_variant_unref (reply); - - return value; -} - -static gboolean -get_login_window_session_id_for_ck (GDBusConnection *connection, - const char *seat_id, - char **session_id) -{ - gboolean can_activate_sessions; - const char **sessions; - int i; - - *session_id = NULL; - sessions = NULL; - - g_debug ("checking if seat can activate sessions"); - - can_activate_sessions = seat_can_activate_sessions (connection, seat_id); - if (! can_activate_sessions) { - g_debug ("seat is unable to activate sessions"); - return FALSE; - } - - sessions = seat_get_sessions (connection, seat_id); - for (i = 0; sessions [i] != NULL; i++) { - const char *ssid; - - ssid = sessions [i]; - - if (session_is_login_window (connection, ssid)) { - *session_id = g_strdup (ssid); - break; - } - } - g_free (sessions); - - return TRUE; -} - -static gboolean -goto_login_session_for_ck (GDBusConnection *connection, - GError **error) -{ - gboolean ret; - gboolean res; - char *session_id; - char *seat_id; - - ret = FALSE; - - /* First look for any existing LoginWindow sessions on the seat. - If none are found, create a new one. */ - - seat_id = get_current_seat_id (connection); - if (seat_id == NULL || seat_id[0] == '\0') { - g_debug ("seat id is not set; can't switch sessions"); - g_set_error (error, GDM_COMMON_ERROR, 0, _("Could not identify the current session.")); - - return FALSE; - } - - res = get_login_window_session_id_for_ck (connection, seat_id, &session_id); - if (! res) { - g_set_error (error, GDM_COMMON_ERROR, 1, _("User unable to switch sessions.")); - return FALSE; - } - - if (session_id != NULL) { - res = activate_session_id_for_ck (connection, seat_id, session_id); - if (res) { - ret = TRUE; - } - } - - if (! ret && g_strcmp0 (seat_id, "/org/freedesktop/ConsoleKit/Seat1") == 0) { - res = create_transient_display (connection, error); - if (res) { - ret = TRUE; - } - } - - return ret; -} -#endif - #ifdef WITH_SYSTEMD static gboolean @@ -844,11 +544,7 @@ gdm_goto_login_session (GError **error) } #endif -#ifdef WITH_CONSOLE_KIT - return goto_login_session_for_ck (connection, error); -#else return FALSE; -#endif } static void |