diff options
author | David Gibson <david@gibson.dropbear.id.au> | 2025-03-05 17:15:04 +1100 |
---|---|---|
committer | Stefano Brivio <sbrivio@redhat.com> | 2025-03-07 02:21:24 +0100 |
commit | e36c35c952ef0848383cba8ef71e13cf25dab2da (patch) | |
tree | aeb5ccef8959ee0caf6e3d57803bb049f9d7613c | |
parent | 57d2db370b9c12aca84901d968c2c31db89ca462 (diff) | |
download | passt-e36c35c952ef0848383cba8ef71e13cf25dab2da.tar passt-e36c35c952ef0848383cba8ef71e13cf25dab2da.tar.gz passt-e36c35c952ef0848383cba8ef71e13cf25dab2da.tar.bz2 passt-e36c35c952ef0848383cba8ef71e13cf25dab2da.tar.lz passt-e36c35c952ef0848383cba8ef71e13cf25dab2da.tar.xz passt-e36c35c952ef0848383cba8ef71e13cf25dab2da.tar.zst passt-e36c35c952ef0848383cba8ef71e13cf25dab2da.zip |
log: Don't export passt_vsyslog()
passt_vsyslog() is an exposed function in log.h. However it shouldn't
be called from outside log.c: it writes specifically to the system log,
and most code should call passt's logging helpers which might go to the
syslog or to a log file.
Make passt_vsyslog() local to log.c. This requires a code motion to avoid
a forward declaration.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
-rw-r--r-- | log.c | 48 | ||||
-rw-r--r-- | log.h | 1 |
2 files changed, 24 insertions, 25 deletions
@@ -250,6 +250,30 @@ static void logfile_write(bool newline, bool cont, int pri, } /** + * passt_vsyslog() - vsyslog() implementation not using heap memory + * @newline: Append newline at the end of the message, if missing + * @pri: Facility and level map, same as priority for vsyslog() + * @format: Same as vsyslog() format + * @ap: Same as vsyslog() ap + */ +static void passt_vsyslog(bool newline, int pri, const char *format, va_list ap) +{ + char buf[BUFSIZ]; + int n; + + /* Send without timestamp, the system logger should add it */ + n = snprintf(buf, BUFSIZ, "<%i> %s: ", pri, log_ident); + + n += vsnprintf(buf + n, BUFSIZ - n, format, ap); + + if (newline && format[strlen(format)] != '\n') + n += snprintf(buf + n, BUFSIZ - n, "\n"); + + if (log_sock >= 0 && send(log_sock, buf, n, 0) != n && log_stderr) + FPRINTF(stderr, "Failed to send %i bytes to syslog\n", n); +} + +/** * vlogmsg() - Print or send messages to log or output files as configured * @newline: Append newline at the end of the message, if missing * @cont: Continuation of a previous message, on the same line @@ -374,30 +398,6 @@ void __setlogmask(int mask) } /** - * passt_vsyslog() - vsyslog() implementation not using heap memory - * @newline: Append newline at the end of the message, if missing - * @pri: Facility and level map, same as priority for vsyslog() - * @format: Same as vsyslog() format - * @ap: Same as vsyslog() ap - */ -void passt_vsyslog(bool newline, int pri, const char *format, va_list ap) -{ - char buf[BUFSIZ]; - int n; - - /* Send without timestamp, the system logger should add it */ - n = snprintf(buf, BUFSIZ, "<%i> %s: ", pri, log_ident); - - n += vsnprintf(buf + n, BUFSIZ - n, format, ap); - - if (newline && format[strlen(format)] != '\n') - n += snprintf(buf + n, BUFSIZ - n, "\n"); - - if (log_sock >= 0 && send(log_sock, buf, n, 0) != n && log_stderr) - FPRINTF(stderr, "Failed to send %i bytes to syslog\n", n); -} - -/** * logfile_init() - Open log file and write header with PID, version, path * @name: Identifier for header: passt or pasta * @path: Path to log file @@ -55,7 +55,6 @@ void trace_init(int enable); void __openlog(const char *ident, int option, int facility); void logfile_init(const char *name, const char *path, size_t size); -void passt_vsyslog(bool newline, int pri, const char *format, va_list ap); void __setlogmask(int mask); #endif /* LOG_H */ |