diff options
author | Lennart Poettering <lennart@poettering.net> | 2024-05-08 10:38:11 +0200 |
---|---|---|
committer | Luca Boccassi <bluca@debian.org> | 2024-06-12 00:17:38 +0200 |
commit | ac908152b3b43a49f793d225c075423422cd3e33 (patch) | |
tree | 522fc38f16493c3a75f9982dc794ce03cb150305 | |
parent | meson: update version to 257~devel (diff) | |
download | systemd-ac908152b3b43a49f793d225c075423422cd3e33.tar.xz systemd-ac908152b3b43a49f793d225c075423422cd3e33.zip |
hostnamed: don't allow hostnamed to exit on idle if varlink connections are still ongoing
And while we are at it, ongoing PK authorizations are also a reason to
block exit on idle.
-rw-r--r-- | src/hostname/hostnamed.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/src/hostname/hostnamed.c b/src/hostname/hostnamed.c index 82d08803fa..fe1216fc1c 100644 --- a/src/hostname/hostnamed.c +++ b/src/hostname/hostnamed.c @@ -1682,6 +1682,13 @@ static int connect_varlink(Context *c) { return 0; } +static bool context_check_idle(void *userdata) { + Context *c = ASSERT_PTR(userdata); + + return varlink_server_current_connections(c->varlink_server) == 0 && + hashmap_isempty(c->polkit_registry); +} + static int run(int argc, char *argv[]) { _cleanup_(context_destroy) Context context = { .hostname_source = _HOSTNAME_INVALID, /* appropriate value will be set later */ @@ -1731,8 +1738,8 @@ static int run(int argc, char *argv[]) { context.bus, "org.freedesktop.hostname1", DEFAULT_EXIT_USEC, - /* check_idle= */ NULL, - /* userdata= */ NULL); + context_check_idle, + &context); if (r < 0) return log_error_errno(r, "Failed to run event loop: %m"); |