chiark / gitweb /
logind: update state file after generating the session fifo, not before
authorLennart Poettering <lennart@poettering.net>
Fri, 26 Jul 2013 15:32:19 +0000 (17:32 +0200)
committerLennart Poettering <lennart@poettering.net>
Fri, 26 Jul 2013 15:33:01 +0000 (17:33 +0200)
https://bugs.freedesktop.org/show_bug.cgi?id=67273

src/login/logind-dbus.c
src/login/logind-session-dbus.c
src/machine/machined-dbus.c

index 39af637d1b03d0996f562d5848292786f37e019d..b5e975a9f79966f659b7997540fdc26311a43202 100644 (file)
@@ -643,6 +643,10 @@ static int bus_manager_create_session(Manager *m, DBusMessage *message) {
 
         session->create_message = dbus_message_ref(message);
 
+        /* Now, let's wait until the slice unit and stuff got
+         * created. We send the reply back from
+         * session_send_create_reply().*/
+
         return 0;
 
 fail:
@@ -2356,7 +2360,6 @@ DBusHandlerResult bus_message_filter(
                                 if (streq_ptr(path, s->scope_job)) {
                                         free(s->scope_job);
                                         s->scope_job = NULL;
-                                        session_save(s);
 
                                         if (s->started) {
                                                 if (streq(result, "done"))
@@ -2366,6 +2369,8 @@ DBusHandlerResult bus_message_filter(
                                                         session_send_create_reply(s, &error);
                                                 }
                                         }
+
+                                        session_save(s);
                                 }
 
                                 session_add_to_gc_queue(s);
index 62b9ffd52a7f150cd63e276640f8fa622b9b2157..210f7564da86d1771017232b88951eb5497aa896 100644 (file)
@@ -535,6 +535,10 @@ int session_send_create_reply(Session *s, DBusError *error) {
         if (!s->create_message)
                 return 0;
 
+        /* This is called after the session scope was successfully
+         * created, and finishes where bus_manager_create_session()
+         * left off. */
+
         if (error) {
                 DBusError buffer;
 
index 1e8bc609a3598340221e7a64a832e73b066fd72c..6c4d50b3a2274fdcb961320ea04d16835ed84712 100644 (file)
@@ -543,7 +543,6 @@ DBusHandlerResult bus_message_filter(
                         if (streq_ptr(path, mm->scope_job)) {
                                 free(mm->scope_job);
                                 mm->scope_job = NULL;
-                                machine_save(mm);
 
                                 if (mm->started) {
                                         if (streq(result, "done"))
@@ -553,6 +552,8 @@ DBusHandlerResult bus_message_filter(
                                                 machine_send_create_reply(mm, &error);
                                         }
                                 }
+
+                                machine_save(mm);
                         }
 
                         machine_add_to_gc_queue(mm);