aboutsummaryrefslogtreecommitdiffstats
path: root/Source/charon
diff options
context:
space:
mode:
Diffstat (limited to 'Source/charon')
-rw-r--r--Source/charon/logger.c131
-rw-r--r--Source/charon/logger.h96
2 files changed, 155 insertions, 72 deletions
diff --git a/Source/charon/logger.c b/Source/charon/logger.c
index f1943bb46..e83917288 100644
--- a/Source/charon/logger.c
+++ b/Source/charon/logger.c
@@ -28,8 +28,12 @@
#include <syslog.h>
#include <stdarg.h>
+#include <string.h>
-
+/**
+ * Maximum length of al log entry (only used for logger_s.log)
+ */
+#define MAX_LOG 8192
/**
* @brief The logger object
@@ -41,10 +45,6 @@ struct private_logger_s {
*/
logger_t public;
/**
- * fd to log, NULL for syslog
- */
- FILE *target;
- /**
* detail-level of logger
*/
logger_level_t level;
@@ -57,34 +57,96 @@ struct private_logger_s {
/**
* implements logger_t-function log
- *
+ * @see logger_s.log
*/
static status_t logg(private_logger_t *this, logger_level_t loglevel, char *format, ...)
{
if ((this->level & loglevel) == loglevel)
{
+ char buffer[MAX_LOG];
+ snprintf(buffer, MAX_LOG, "%s: %s", this->name, format);
va_list args;
va_start(args, format);
-
- if (this->target)
- {
- fprintf(this->target, format, args);
- fprintf(this->target, "\n");
- }
- else
- {
- syslog(LOG_INFO, format, args);
- }
+ vsyslog(LOG_INFO, buffer, args);
va_end(args);
}
+
+ return SUCCESS;
+}
+
+
+/**
+ * implements logger_t-function destroy
+ * @see logger_s.log_bytes
+ */
+static status_t log_bytes(private_logger_t *this, logger_level_t loglevel, char *label, char *bytes, size_t len)
+{
+ if ((this->level & loglevel) == loglevel)
+ {
+ char buffer[64];
+ char *buffer_pos;
+ char *bytes_pos, *bytes_roof;
+ int i;
+
+ syslog(LOG_INFO, "%s: %s (%d bytes)", this->name, label, len);
-
+ bytes_pos = bytes;
+ bytes_roof = bytes + len;
+ buffer_pos = buffer;
+
+ for (i = 1; bytes_pos < bytes_roof; i++)
+ {
+ static const char hexdig[] = "0123456789ABCDEF";
+ *buffer_pos++ = hexdig[(*bytes_pos >> 4) & 0xF];
+ *buffer_pos++ = hexdig[ *bytes_pos & 0xF];
+ if ((i % 16) == 0)
+ {
+ *buffer_pos++ = '\0';
+ buffer_pos = buffer;
+ syslog(LOG_INFO, "| %s", buffer);
+ }
+ else if ((i % 8) == 0)
+ {
+ *buffer_pos++ = ' ';
+ *buffer_pos++ = ' ';
+ *buffer_pos++ = ' ';
+ }
+ else if ((i % 4) == 0)
+ {
+ *buffer_pos++ = ' ';
+ *buffer_pos++ = ' ';
+ }
+ else
+ {
+ *buffer_pos++ = ' ';
+ }
+
+ bytes_pos++;
+ }
+
+ *buffer_pos++ = '\0';
+ buffer_pos = buffer;
+ syslog(LOG_INFO, "| %s", buffer);
+ }
+
return SUCCESS;
}
+
+/**
+ * implements logger_t-function log_chunk
+ * @see logger_s.log_chunk
+ */
+static status_t log_chunk(logger_t *this, logger_level_t loglevel, char *label, chunk_t *chunk)
+{
+ this->log_bytes(this, loglevel, label, chunk->ptr, chunk->len);
+ return SUCCESS;
+}
+
+
/**
* implements logger_t-function enable_level
- *
+ * @see logger_s.enable_level
*/
static status_t enable_level(private_logger_t *this, logger_level_t log_level)
{
@@ -94,33 +156,28 @@ static status_t enable_level(private_logger_t *this, logger_level_t log_level)
/**
* implements logger_t-function disable_level
- *
+ * @see logger_s.disable_level
*/
static status_t disable_level(private_logger_t *this, logger_level_t log_level)
{
- this->level &= (~log_level);
+ this->level &= ~log_level;
return SUCCESS;
}
/**
* implements logger_t-function destroy
- *
- */
+ * @see logger_s.destroy
+ */
static status_t destroy(private_logger_t *this)
{
- if (this->target)
- {
- fclose(this->target);
- }
allocator_free(this);
return SUCCESS;
}
/*
* Described in Header
- *
*/
-logger_t *logger_create(char *logger_name, char *file, logger_level_t log_level)
+logger_t *logger_create(char *logger_name, logger_level_t log_level)
{
private_logger_t *this = allocator_alloc_thing(private_logger_t);
@@ -130,6 +187,8 @@ logger_t *logger_create(char *logger_name, char *file, logger_level_t log_level)
}
this->public.log = (status_t(*)(logger_t*,logger_level_t,char*,...))logg;
+ this->public.log_bytes = (status_t(*)(logger_t*, logger_level_t, char*,char*,size_t))log_bytes;
+ this->public.log_chunk = log_chunk;
this->public.enable_level = (status_t(*)(logger_t*,logger_level_t))enable_level;
this->public.disable_level = (status_t(*)(logger_t*,logger_level_t))disable_level;
this->public.destroy = (status_t(*)(logger_t*))destroy;
@@ -137,21 +196,7 @@ logger_t *logger_create(char *logger_name, char *file, logger_level_t log_level)
this->level = log_level;
this->name = logger_name;
- /* use system logger ? */
- if (file)
- {
- this->target = fopen(file, "a");
- if (this->target == NULL)
- {
- allocator_free(this);
- return NULL;
- }
- }
- else
- {
- this->target = NULL;
- openlog("charon", 0, LOG_DAEMON);
- }
+ openlog("charon", 0, LOG_DAEMON);
return (logger_t*)this;
}
diff --git a/Source/charon/logger.h b/Source/charon/logger.h
index 8656edfff..076944b8e 100644
--- a/Source/charon/logger.h
+++ b/Source/charon/logger.h
@@ -23,13 +23,17 @@
#ifndef LOGGER_H_
#define LOGGER_H_
+
+#include <freeswan.h>
+#include <pluto/constants.h>
+#include <pluto/defs.h>
+
#include "types.h"
/**
* Log Levels supported by the logger object
*/
typedef enum logger_level_e logger_level_t;
-
enum logger_level_e {
/**
* basic control messages
@@ -53,58 +57,92 @@ enum logger_level_e {
* @brief The logger object
*/
typedef struct logger_s logger_t;
-struct logger_s {
+struct logger_s {
/**
- * loggs an entry
+ * @brief Log an entry, using printf()-like params.
*
- * function is used like printf
+ * The specefied loglevels must ALL be activated that
+ * the log is done.
*
- * @param this logger_t-object
- * @param loglevel loglevel of specific log entry
- * @param format printf like format string
- * @param ... printf like parameters
- * @return SUCCESS
+ * @param this logger_t-object
+ * @param loglevel or'ed set of loglevels
+ * @param format printf like format string
+ * @param ... printf like parameters
+ * @return
+ * - SUCCESS in any case
*/
status_t (*log) (logger_t *this, logger_level_t log_level, char *format, ...);
+
+ /**
+ * @brief Log some bytes, useful for debugging.
+ *
+ * The specefied loglevels must ALL be activated that
+ * the log is done.
+ *
+ * @param this logger_t-object
+ * @param loglevel or'ed set of loglevels
+ * @param label a labeling name, logged with the bytes
+ * @param bytes pointer to the bytes to dump
+ * @param len number of bytes to dump
+ * @return
+ * - SUCCESS in any case
+ */
+ status_t (*log_bytes) (logger_t *this, logger_level_t loglevel, char *label, char *bytes, size_t len);
+
+ /**
+ * @brief Log a chunk, useful for debugging.
+ *
+ * The specefied loglevels must ALL be activated that
+ * the log is done.
+ *
+ * @param this logger_t-object
+ * @param loglevel or'ed set of loglevels
+ * @param label a labeling name, logged with the bytes
+ * @param chunk pointer to a chunk to log
+ * @return
+ * - SUCCESS in any case
+ */
+ status_t (*log_chunk) (logger_t *this, logger_level_t loglevel, char *label, chunk_t *chunk);
/**
- * enables a loglevel for the current logger_t-object
+ * @brief Enables a loglevel for the current logger_t-object.
*
- * @param this logger_t-object
- * @param log_level loglevel to enable
- * @return SUCCESS
+ * @param this logger_t-object
+ * @param log_level loglevel to enable
+ * @return
+ * - SUCCESS in any case
*/
status_t (*enable_level) (logger_t *this, logger_level_t log_level);
/**
- * disables a loglevel for the current logger_t-object
+ * @brief Disables a loglevel for the current logger_t-object.
*
- * @param this logger_t-object
- * @param log_level loglevel to disable
- * @return SUCCESS
- */
+ * @param this logger_t-object
+ * @param log_level loglevel to enable
+ * @return
+ * - SUCCESS in any case
+ */
status_t (*disable_level) (logger_t *this, logger_level_t log_level);
/**
- * @brief destroys a logger_t object
+ * @brief destroys a logger_t object.
*
- * @param this logger_t object
- * @return SUCCESS if succeeded, FAILED otherwise
+ * @param this logger_t object
+ * @return
+ * - SUCCESS in any case
*/
status_t (*destroy) (logger_t *this);
};
/**
- * Constructor to create a logger_t-object
+ * @brief Constructor to create a logger_t-object.
*
- * @param logger_name Name for the logger_t-object
- * @param file FILE pointer to write the log-messages to. If NULL
- * syslogger is used.
- * @param log_level to assign to the new logger_t-object
- * @return logger_t-object or NULL if failed
+ * @param logger_name Name for the logger_t-object
+ * @param log_level or'ed set of log_levels to assign to the new logger_t-object
+ * @return logger_t-object or NULL if failed
*/
-logger_t *logger_create(char *logger_name, char *file, logger_level_t log_level);
+logger_t *logger_create(char *logger_name, logger_level_t log_level);
-#endif /*LOGGER_H_*/
+#endif /*LOGGER_H_*/