X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Flogfile.c;h=6d0f6e07826f2eb5391a64bc93db72e642948362;hb=0af747df59d57fc972b27e98c175f26d873d7814;hp=382386b75552fa0915d9ade6ded18bc5b9954f3d;hpb=5b5f7f4e3dd28d9e41469c331f3f9f6a09e3147b;p=collectd.git diff --git a/src/logfile.c b/src/logfile.c index 382386b7..6d0f6e07 100644 --- a/src/logfile.c +++ b/src/logfile.c @@ -39,12 +39,14 @@ static pthread_mutex_t file_lock = PTHREAD_MUTEX_INITIALIZER; static char *log_file = NULL; static int print_timestamp = 1; +static int print_severity = 0; static const char *config_keys[] = { "LogLevel", "File", - "Timestamp" + "Timestamp", + "PrintSeverity" }; static int config_keys_num = STATIC_ARRAY_SIZE (config_keys); @@ -74,12 +76,15 @@ static int logfile_config (const char *key, const char *value) log_file = strdup (value); } else if (0 == strcasecmp (key, "Timestamp")) { - if ((strcasecmp (value, "false") == 0) - || (strcasecmp (value, "no") == 0) - || (strcasecmp (value, "off") == 0)) + if (IS_FALSE (value)) print_timestamp = 0; else print_timestamp = 1; + } else if (0 == strcasecmp(key, "PrintSeverity")) { + if (IS_FALSE (value)) + print_severity = 0; + else + print_severity = 1; } else { return -1; @@ -87,12 +92,37 @@ static int logfile_config (const char *key, const char *value) return 0; } /* int logfile_config (const char *, const char *) */ -static void logfile_print (const char *msg, time_t timestamp_time) +static void logfile_print (const char *msg, int severity, time_t timestamp_time) { FILE *fh; int do_close = 0; struct tm timestamp_tm; char timestamp_str[64]; + char level_str[16] = ""; + + if (print_severity) + { + switch (severity) + { + case LOG_ERR: + snprintf(level_str, sizeof (level_str), "[error] "); + break; + case LOG_WARNING: + snprintf(level_str, sizeof (level_str), "[warning] "); + break; + case LOG_NOTICE: + snprintf(level_str, sizeof (level_str), "[notice] "); + break; + case LOG_INFO: + snprintf(level_str, sizeof (level_str), "[info] "); + break; + case LOG_DEBUG: + snprintf(level_str, sizeof (level_str), "[debug] "); + break; + default: + break; + } + } if (print_timestamp) { @@ -130,9 +160,9 @@ static void logfile_print (const char *msg, time_t timestamp_time) else { if (print_timestamp) - fprintf (fh, "[%s] %s\n", timestamp_str, msg); + fprintf (fh, "[%s] %s%s\n", timestamp_str, level_str, msg); else - fprintf (fh, "%s\n", msg); + fprintf (fh, "%s%s\n", level_str, msg); if (do_close != 0) fclose (fh); @@ -143,15 +173,17 @@ static void logfile_print (const char *msg, time_t timestamp_time) return; } /* void logfile_print */ -static void logfile_log (int severity, const char *msg) +static void logfile_log (int severity, const char *msg, + user_data_t __attribute__((unused)) *user_data) { if (severity > log_level) return; - logfile_print (msg, time (NULL)); + logfile_print (msg, severity, time (NULL)); } /* void logfile_log (int, const char *) */ -static int logfile_notification (const notification_t *n) +static int logfile_notification (const notification_t *n, + user_data_t __attribute__((unused)) *user_data) { char buf[1024] = ""; char *buf_ptr = buf; @@ -185,7 +217,8 @@ static int logfile_notification (const notification_t *n) buf[sizeof (buf) - 1] = '\0'; - logfile_print (buf, n->time); + logfile_print (buf, LOG_INFO, + (n->time > 0) ? n->time : time (NULL)); return (0); } /* int logfile_notification */ @@ -194,8 +227,9 @@ void module_register (void) { plugin_register_config ("logfile", logfile_config, config_keys, config_keys_num); - plugin_register_log ("logfile", logfile_log); - plugin_register_notification ("logfile", logfile_notification); + plugin_register_log ("logfile", logfile_log, /* user_data = */ NULL); + plugin_register_notification ("logfile", logfile_notification, + /* user_data = */ NULL); } /* void module_register (void) */ /* vim: set sw=4 ts=4 tw=78 noexpandtab : */