diff options
Diffstat (limited to 'Source/charon/utils')
-rw-r--r-- | Source/charon/utils/logger.c | 88 | ||||
-rw-r--r-- | Source/charon/utils/logger.h | 2 | ||||
-rw-r--r-- | Source/charon/utils/logger_manager.c | 37 | ||||
-rw-r--r-- | Source/charon/utils/logger_manager.h | 9 |
4 files changed, 112 insertions, 24 deletions
diff --git a/Source/charon/utils/logger.c b/Source/charon/utils/logger.c index ab6836240..ec892f2ca 100644 --- a/Source/charon/utils/logger.c +++ b/Source/charon/utils/logger.c @@ -25,6 +25,7 @@ #include <string.h> #include <stdio.h> #include <time.h> +#include <pthread.h> #include "logger.h" @@ -59,14 +60,81 @@ struct private_logger_s { */ FILE *output; + /** + * should a thread_id be included in the log? + */ + bool log_thread_id; + /* private functions */ /** * Logs a message to the associated log file. */ void (*log_to_file) (private_logger_t *this, char *format, ...); + /** + * applies a prefix to string and stores it in buffer + * + * @warning: buffer must be at least MAX_LOG long + */ + void (*prepend_prefix) (private_logger_t *this, logger_level_t loglevel, char *string, char *buffer); }; /** + * Implements private_logger_t.prepend_prefix + */ +static void prepend_prefix(private_logger_t *this, logger_level_t loglevel, char *string, char *buffer) +{ + char log_type, log_details; + if (loglevel & CONTROL) + { + log_type = '~'; + } + else if (loglevel & ERROR) + { + log_type = '!'; + } + else if (loglevel & RAW) + { + log_type = '#'; + } + else if (loglevel & PRIVATE) + { + log_type = '?'; + } + else + { + log_type = '-'; + } + + if (loglevel & ALL) + { + log_details = '3'; + } + else if (loglevel & MOST) + { + log_details = '2'; + } + else if (loglevel & MORE) + { + log_details = '1'; + } + else + { + log_details = '0'; + } + + + if (this->log_thread_id) + { + snprintf(buffer, MAX_LOG, "[%c%c] [%s] @%u %s", log_type, log_details, this->name, (int)pthread_self(), string); + } + else + { + snprintf(buffer, MAX_LOG, "[%c%c] [%s] %s", log_type, log_details, this->name, string); + } + +} + +/** * Implements logger_t-function log. * @see logger_s.log. * @@ -78,11 +146,12 @@ static status_t logg(private_logger_t *this, logger_level_t loglevel, char *form { char buffer[MAX_LOG]; va_list args; + if (this->output == NULL) { /* syslog */ - snprintf(buffer, MAX_LOG, "%s: %s", this->name, format); + this->prepend_prefix(this, loglevel, format, buffer); va_start(args, format); vsyslog(LOG_INFO, buffer, args); va_end(args); @@ -90,7 +159,7 @@ static status_t logg(private_logger_t *this, logger_level_t loglevel, char *form else { /* File output */ - snprintf(buffer, MAX_LOG, "File %s: %s", this->name, format); + this->prepend_prefix(this, loglevel, format, buffer); va_start(args, format); this->log_to_file(this, buffer, args); va_end(args); @@ -125,17 +194,22 @@ static status_t log_bytes(private_logger_t *this, logger_level_t loglevel, char { if ((this->level & loglevel) == loglevel) { - char buffer[64]; + char buffer[MAX_LOG]; + char *format; char *buffer_pos; char *bytes_pos, *bytes_roof; int i; + + + format = "%s (%d bytes)"; + this->prepend_prefix(this, loglevel, format, buffer); if (this->output == NULL) { - syslog(LOG_INFO, "%s: %s (%d bytes)", this->name, label, len); + syslog(LOG_INFO, buffer, label, len); }else { - this->log_to_file(this,"%s: %s (%d bytes)", this->name, label, len); + this->log_to_file(this, buffer, label, len); } bytes_pos = bytes; @@ -240,7 +314,7 @@ static status_t destroy(private_logger_t *this) /* * Described in Header */ -logger_t *logger_create(char *logger_name, logger_level_t log_level,FILE * output) +logger_t *logger_create(char *logger_name, logger_level_t log_level, bool log_thread_id, FILE * output) { private_logger_t *this = allocator_alloc_thing(private_logger_t); @@ -262,9 +336,11 @@ logger_t *logger_create(char *logger_name, logger_level_t log_level,FILE * outpu this->public.destroy = (status_t(*)(logger_t*))destroy; this->log_to_file = log_to_file; + this->prepend_prefix = prepend_prefix; /* private variables */ this->level = log_level; + this->log_thread_id = log_thread_id; this->name = allocator_alloc(strlen(logger_name) + 1); if (this->name == NULL) { diff --git a/Source/charon/utils/logger.h b/Source/charon/utils/logger.h index 04fa8cdd4..286491fb6 100644 --- a/Source/charon/utils/logger.h +++ b/Source/charon/utils/logger.h @@ -164,7 +164,7 @@ struct logger_s { * @param output FILE * if log has to go on a file output, NULL for syslog * @return logger_t object or NULL if failed */ -logger_t *logger_create(char *logger_name, logger_level_t log_level,FILE * output); +logger_t *logger_create(char *logger_name, logger_level_t log_level, bool log_thread_id, FILE * output); #endif /*LOGGER_H_*/ diff --git a/Source/charon/utils/logger_manager.c b/Source/charon/utils/logger_manager.c index 657d2e3de..d00761dc0 100644 --- a/Source/charon/utils/logger_manager.c +++ b/Source/charon/utils/logger_manager.c @@ -29,15 +29,16 @@ mapping_t logger_context_t_mappings[] = { {PARSER, "PARSER"}, - {GENERATOR, "GENERATOR"}, + {GENERATOR, "GENRAT"}, {IKE_SA, "IKE_SA"}, - {IKE_SA_MANAGER, "IKE_SA_MANAGER"}, - {MESSAGE, "MESSAGE"}, - {THREAD_POOL, "THREAD_POOL"}, - {WORKER_THREAD, "WORKER_THREAD"}, - {SCHEDULER_THREAD, "SCHEDULER_THREAD"}, - {SENDER_THREAD, "SENDER_THREAD"}, - {RECEIVER_THREAD, "RECEIVER_THREAD"}, + {IKE_SA_MANAGER, "ISAMGR"}, + {MESSAGE, "MESSAG"}, + {THREAD_POOL, "THPOOL"}, + {WORKER, "WORKER"}, + {SCHEDULER, "SCHEDU"}, + {SENDER, "SENDER"}, + {RECEIVER, "RECEVR"}, + {SOCKET, "SOCKET"}, {TESTER, "TESTER"}, {DAEMON, "DAEMON"}, }; @@ -114,21 +115,31 @@ static logger_t *create_logger(private_logger_manager_t *this, logger_context_t { char * context_name; + bool log_thread_ids = TRUE; FILE * output = NULL; char buffer[MAX_LOGGER_NAME]; loggers_entry_t *entry; logger_t *logger; logger_level_t logger_level = this->public.get_logger_level(&(this->public),context); + + context_name = mapping_find(logger_context_t_mappings,context); switch(context) { case TESTER: - context_name = "TESTER"; + log_thread_ids = FALSE; output = stdout; break; + case SCHEDULER: + case SENDER: + case RECEIVER: + case THREAD_POOL: + case SOCKET: + case DAEMON: + log_thread_ids = FALSE; + break; default: - context_name = mapping_find(logger_context_t_mappings,context); - break; + break; } /* logger manager is thread save */ pthread_mutex_lock(&(this->mutex)); @@ -136,11 +147,11 @@ static logger_t *create_logger(private_logger_manager_t *this, logger_context_t { snprintf(buffer, MAX_LOGGER_NAME, "%s - %s",context_name,name); /* create logger with default log_level */ - logger = logger_create(buffer,logger_level,output); + logger = logger_create(buffer,logger_level,log_thread_ids,output); } else { - logger = logger_create(context_name,logger_level,output); + logger = logger_create(context_name,logger_level,log_thread_ids,output); } diff --git a/Source/charon/utils/logger_manager.h b/Source/charon/utils/logger_manager.h index 71c693a1b..2bd305939 100644 --- a/Source/charon/utils/logger_manager.h +++ b/Source/charon/utils/logger_manager.h @@ -39,10 +39,11 @@ enum logger_context_e{ IKE_SA_MANAGER, MESSAGE, THREAD_POOL, - WORKER_THREAD, - SCHEDULER_THREAD, - SENDER_THREAD, - RECEIVER_THREAD, + WORKER, + SCHEDULER, + SENDER, + RECEIVER, + SOCKET, TESTER, DAEMON, }; |