diff options
| author | Lennart Poettering <lennart@poettering.net> | 2016-06-30 17:37:21 -0700 | 
|---|---|---|
| committer | Lennart Poettering <lennart@poettering.net> | 2016-07-19 14:21:49 +0200 | 
| commit | c24f1f9df1a79f413dc1cdad27341027e58d2a1f (patch) | |
| tree | ec925610539845afd5efcd4e603b52fcd12e89b3 /src | |
| parent | bb557f90f842fb9646a83fd3c21ba359bb8c0f28 (diff) | |
sd-journal: when formatting log messages, implicitly strip trailing whitespace
When converting log messages from human readable text into binary records to
send off to journald in sd_journal_print(), strip trailing whitespace in the
log message. This way, handling of logs made via syslog(), stdout/stderr and
sd_journal_print() are treated the same way: trailing (but not leading)
whitespace is automatically removed, in particular \n and \r. Note that in case
of syslog() and stdout/stderr based logging the stripping takes place
server-side though, while for the native protocol based transport this takes
place client-side. This is because in the former cases conversion from
free-form human-readable strings into structured, binary log records takes
place on the server-side while for journal-native logging it happens on the
client side, and after conversion into binary records we probably shouldn't
alter the data anymore.
See: #3416
Diffstat (limited to 'src')
| -rw-r--r-- | src/journal/journal-send.c | 7 | 
1 files changed, 7 insertions, 0 deletions
| diff --git a/src/journal/journal-send.c b/src/journal/journal-send.c index 5e8a3e3200..1b92585488 100644 --- a/src/journal/journal-send.c +++ b/src/journal/journal-send.c @@ -107,6 +107,9 @@ _public_ int sd_journal_printv(int priority, const char *format, va_list ap) {          memcpy(buffer, "MESSAGE=", 8);          vsnprintf(buffer+8, sizeof(buffer) - 8, format, ap); +        /* Strip trailing whitespace, keep prefix whitespace. */ +        (void) strstrip(buffer); +          zero(iov);          IOVEC_SET_STRING(iov[0], buffer);          IOVEC_SET_STRING(iov[1], p); @@ -158,6 +161,8 @@ _printf_(1, 0) static int fill_iovec_sprintf(const char *format, va_list ap, int                  VA_FORMAT_ADVANCE(format, ap); +                (void) strstrip(buffer); /* strip trailing whitespace, keep prefixing whitespace */ +                  IOVEC_SET_STRING(iov[i++], buffer);                  format = va_arg(ap, char *); @@ -471,6 +476,8 @@ _public_ int sd_journal_printv_with_location(int priority, const char *file, con          memcpy(buffer, "MESSAGE=", 8);          vsnprintf(buffer+8, sizeof(buffer) - 8, format, ap); +        (void) strstrip(buffer); /* strip trailing whitespace, keep prefixing whitespace */ +          /* func is initialized from __func__ which is not a macro, but           * a static const char[], hence cannot easily be prefixed with           * CODE_FUNC=, hence let's do it manually here. */ | 
