From: Mike Yuan Date: Wed, 3 Apr 2024 14:54:48 +0000 (+0800) Subject: core/manager: use cellescape and don't be too aggressive X-Git-Tag: v256-rc1~322^2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a2098d8bf73fc043b919db02b49b73e94a63ad5c;p=thirdparty%2Fsystemd.git core/manager: use cellescape and don't be too aggressive Addresses https://github.com/systemd/systemd/pull/32068#issuecomment-2034799862 --- diff --git a/src/core/manager.c b/src/core/manager.c index b8b5f085e61..0103c582b52 100644 --- a/src/core/manager.c +++ b/src/core/manager.c @@ -2586,22 +2586,17 @@ static void manager_invoke_notify_message( UNIT_VTABLE(u)->notify_message(u, ucred, tags, fds); else if (DEBUG_LOGGING) { - _cleanup_free_ char *buf = NULL, *x = NULL, *y = NULL; + _cleanup_free_ char *joined = strv_join(tags, ", "); + char buf[CELLESCAPE_DEFAULT_LENGTH]; - buf = strv_join(tags, ", "); - if (buf) - x = ellipsize(buf, 20, 90); - if (x) - y = cescape(x); - - log_unit_debug(u, "Got notification message \"%s\", ignoring.", strnull(y)); + log_unit_debug(u, "Got notification message from unexpected unit type, ignoring: %s", + joined ? cellescape(buf, sizeof(buf), joined) : "(null)"); } } static int manager_dispatch_notify_fd(sd_event_source *source, int fd, uint32_t revents, void *userdata) { - - _cleanup_fdset_free_ FDSet *fds = NULL; Manager *m = ASSERT_PTR(userdata); + _cleanup_fdset_free_ FDSet *fds = NULL; char buf[NOTIFY_BUFFER_MAX+1]; struct iovec iovec = { .iov_base = buf,