summaryrefslogtreecommitdiff
path: root/src/login
diff options
context:
space:
mode:
authorDavid Tardon <dtardon@redhat.com>2022-07-16 15:10:26 +0200
committerDavid Tardon <dtardon@redhat.com>2022-07-16 15:10:26 +0200
commitc5912adc85445989179cdc0cd8f206683188bd0e (patch)
tree06358c7db5d0676ca905285534d94b0690d3042a /src/login
parent08894b568f03fc06bb961c6c731be0c877ff7786 (diff)
downloadsystemd-c5912adc85445989179cdc0cd8f206683188bd0e.tar.gz
loginctl: add linger status to list-users output
Fixes: #3907
Diffstat (limited to 'src/login')
-rw-r--r--src/login/loginctl.c21
1 files changed, 17 insertions, 4 deletions
diff --git a/src/login/loginctl.c b/src/login/loginctl.c
index 83f25135a2..d00a280e66 100644
--- a/src/login/loginctl.c
+++ b/src/login/loginctl.c
@@ -207,25 +207,38 @@ static int list_users(int argc, char *argv[], void *userdata) {
if (r < 0)
return bus_log_parse_error(r);
- table = table_new("uid", "user");
+ table = table_new("uid", "user", "linger");
if (!table)
return log_oom();
(void) table_set_align_percent(table, TABLE_HEADER_CELL(0), 100);
for (;;) {
- const char *user;
+ const char *user, *object;
uint32_t uid;
+ int linger;
- r = sd_bus_message_read(reply, "(uso)", &uid, &user, NULL);
+ r = sd_bus_message_read(reply, "(uso)", &uid, &user, &object);
if (r < 0)
return bus_log_parse_error(r);
if (r == 0)
break;
+ r = sd_bus_get_property_trivial(bus,
+ "org.freedesktop.login1",
+ object,
+ "org.freedesktop.login1.User",
+ "Linger",
+ &error,
+ 'b',
+ &linger);
+ if (r < 0)
+ return log_error_errno(r, "Failed to get linger status: %s", bus_error_message(&error, r));
+
r = table_add_many(table,
TABLE_UID, (uid_t) uid,
- TABLE_STRING, user);
+ TABLE_STRING, user,
+ TABLE_BOOLEAN, linger);
if (r < 0)
return table_log_add_error(r);
}