Blame SOURCES/0026-manager-don-t-set-ran_once-after-running-initial-set.patch

a1b388
From b773eb570d8c5f9d2222ee39eecbc6a622d108d8 Mon Sep 17 00:00:00 2001
a1b388
From: Ray Strode <rstrode@redhat.com>
a1b388
Date: Thu, 30 Aug 2018 16:04:41 -0400
a1b388
Subject: [PATCH 26/51] manager: don't set ran_once after running initial-setup
a1b388
a1b388
GdmManager tracks whether or not the user session has ran
a1b388
once, so it won't autologin a user again after logout.
a1b388
a1b388
Unfortunately the initial-setup session was counting toward the
a1b388
ran_once count preventing initial-setup from logging the user
a1b388
in afterward.
a1b388
a1b388
This commit prevents ran_once from getting set in that case.
a1b388
---
a1b388
 daemon/gdm-manager.c | 4 +++-
a1b388
 1 file changed, 3 insertions(+), 1 deletion(-)
a1b388
a1b388
diff --git a/daemon/gdm-manager.c b/daemon/gdm-manager.c
a1b388
index 367a731cc..c8197a043 100644
a1b388
--- a/daemon/gdm-manager.c
a1b388
+++ b/daemon/gdm-manager.c
a1b388
@@ -1519,105 +1519,107 @@ set_up_session (GdmManager *manager,
a1b388
                 operation->username = username;
a1b388
 
a1b388
                 g_signal_connect (user,
a1b388
                                   "notify::is-loaded",
a1b388
                                   G_CALLBACK (on_user_is_loaded_changed),
a1b388
                                   operation);
a1b388
         }
a1b388
 }
a1b388
 
a1b388
 static void
a1b388
 greeter_display_started (GdmManager *manager,
a1b388
                          GdmDisplay *display)
a1b388
 {
a1b388
         if (manager->priv->ran_once) {
a1b388
                 return;
a1b388
         }
a1b388
 
a1b388
         maybe_start_pending_initial_login (manager, display);
a1b388
 }
a1b388
 
a1b388
 static void
a1b388
 on_display_status_changed (GdmDisplay *display,
a1b388
                            GParamSpec *arg1,
a1b388
                            GdmManager *manager)
a1b388
 {
a1b388
         int         status;
a1b388
         int         display_number = -1;
a1b388
         char       *session_type = NULL;
a1b388
 #ifdef WITH_PLYMOUTH
a1b388
         gboolean    display_is_local = FALSE;
a1b388
+        gboolean    doing_initial_setup = FALSE;
a1b388
         gboolean    quit_plymouth = FALSE;
a1b388
 
a1b388
         g_object_get (display,
a1b388
                       "is-local", &display_is_local,
a1b388
+                      "doing-initial-setup", &doing_initial_setup,
a1b388
                       NULL);
a1b388
         quit_plymouth = display_is_local && manager->priv->plymouth_is_running;
a1b388
 #endif
a1b388
 
a1b388
         g_object_get (display,
a1b388
                       "x11-display-number", &display_number,
a1b388
                       "session-type", &session_type,
a1b388
                       NULL);
a1b388
 
a1b388
         status = gdm_display_get_status (display);
a1b388
 
a1b388
         switch (status) {
a1b388
                 case GDM_DISPLAY_PREPARED:
a1b388
                 case GDM_DISPLAY_MANAGED:
a1b388
                         if ((display_number == -1 && status == GDM_DISPLAY_PREPARED) ||
a1b388
                             (display_number != -1 && status == GDM_DISPLAY_MANAGED)) {
a1b388
                                 char *session_class;
a1b388
 
a1b388
                                 g_object_get (display,
a1b388
                                               "session-class", &session_class,
a1b388
                                               NULL);
a1b388
                                 if (g_strcmp0 (session_class, "greeter") == 0)
a1b388
                                         set_up_session (manager, display);
a1b388
                                 g_free (session_class);
a1b388
                         }
a1b388
 
a1b388
                         if (status == GDM_DISPLAY_MANAGED) {
a1b388
                                 greeter_display_started (manager, display);
a1b388
                         }
a1b388
                         break;
a1b388
                 case GDM_DISPLAY_FAILED:
a1b388
                 case GDM_DISPLAY_UNMANAGED:
a1b388
                 case GDM_DISPLAY_FINISHED:
a1b388
 #ifdef WITH_PLYMOUTH
a1b388
                         if (quit_plymouth) {
a1b388
                                 plymouth_quit_without_transition ();
a1b388
                                 manager->priv->plymouth_is_running = FALSE;
a1b388
                         }
a1b388
 #endif
a1b388
 
a1b388
-                        if (status == GDM_DISPLAY_FINISHED || g_strcmp0 (session_type, "x11") == 0) {
a1b388
+                        if (!doing_initial_setup && (status == GDM_DISPLAY_FINISHED || g_strcmp0 (session_type, "x11") == 0)) {
a1b388
                                 manager->priv->ran_once = TRUE;
a1b388
                         }
a1b388
                         maybe_start_pending_initial_login (manager, display);
a1b388
                         break;
a1b388
                 default:
a1b388
                         break;
a1b388
         }
a1b388
 
a1b388
 }
a1b388
 
a1b388
 static void
a1b388
 on_display_removed (GdmDisplayStore *display_store,
a1b388
                     GdmDisplay      *display,
a1b388
                     GdmManager      *manager)
a1b388
 {
a1b388
         char    *id;
a1b388
 
a1b388
         gdm_display_get_id (display, &id, NULL);
a1b388
         g_dbus_object_manager_server_unexport (manager->priv->object_manager, id);
a1b388
         g_free (id);
a1b388
 
a1b388
         g_signal_handlers_disconnect_by_func (display, G_CALLBACK (on_display_status_changed), manager);
a1b388
 
a1b388
         g_signal_emit (manager, signals[DISPLAY_REMOVED], 0, display);
a1b388
 }
a1b388
 
a1b388
 static void
a1b388
 destroy_start_user_session_operation (StartUserSessionOperation *operation)
a1b388
 {
a1b388
         g_object_set_data (G_OBJECT (operation->session),
a1b388
-- 
a1b388
2.27.0
a1b388