]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
login: fix session_kill(..., KILL_LEADER,...) (#35105)
author12paper <104864644+12paper@users.noreply.github.com>
Sun, 10 Nov 2024 02:13:39 +0000 (03:13 +0100)
committerGitHub <noreply@github.com>
Sun, 10 Nov 2024 02:13:39 +0000 (11:13 +0900)
`loginctl kill-session --kill-whom=leader <N>` (or the D-Bus equivalent)
doesn't work because logind ends up calling `KillUnit(..., "main", ...)`
on a scope unit and these don't have a `MainPID` property. Here, I just
make it send a signal to the `Leader` directly.

src/login/logind-session.c

index 66b4eadf61fc02cd88ff221055168380d7d66b5e..7f359864dc808f3860e92fe12f3444159f147b6b 100644 (file)
@@ -1390,10 +1390,20 @@ SessionState session_get_state(Session *s) {
 int session_kill(Session *s, KillWhom whom, int signo) {
         assert(s);
 
-        if (!s->scope)
-                return -ESRCH;
+        switch (whom) {
+
+        case KILL_ALL:
+                if (!s->scope)
+                        return -ESRCH;
+
+                return manager_kill_unit(s->manager, s->scope, KILL_ALL, signo, NULL);
 
-        return manager_kill_unit(s->manager, s->scope, whom, signo, NULL);
+        case KILL_LEADER:
+                return pidref_kill(&s->leader, signo);
+
+        default:
+                assert_not_reached();
+        }
 }
 
 static int session_open_vt(Session *s, bool reopen) {