chiark / gitweb /
logind: Save the user’s state when a session enters SESSION_ACTIVE
authorPhilip Withnall <philip.withnall@collabora.co.uk>
Tue, 2 Jun 2015 13:17:10 +0000 (14:17 +0100)
committerSven Eden <yamakuzure@gmx.net>
Tue, 14 Mar 2017 09:01:41 +0000 (10:01 +0100)
commitaf750a80c7d0ae8259588f77e14e04cfce824081
tree925f26e5cc74c13e0f18c6509b569c3b2613de3b
parent165d7d44bd29a34a0bc598314884e3204d8f753d
logind: Save the user’s state when a session enters SESSION_ACTIVE

When (for example) switching from X11 to a new VT and logging in there,
creating a new session, the user state file (/run/systemd/users/$uid) is
not updated after the session becomes active. The latest time it is
saved is when the session is in SESSION_OPENING.

This results in a /run/systemd/users/$uid file which contains
STATE=online for the current user on the current active VT, which is
obviously wrong.

As functions like sd_uid_get_state() use this file to get the user’s
state, this could result in things like PolicyKit making incorrect
decisions about the user’s state. (See
https://bugs.freedesktop.org/show_bug.cgi?id=76358.)

Fix this by re-saving the state for a session’s user after completing
the state_job for that session.

https://bugs.freedesktop.org/show_bug.cgi?id=90818
src/login/logind-dbus.c