aboutsummaryrefslogtreecommitdiffstats
path: root/src/libcharon/control/controller.c
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2012-01-23 13:51:21 +0100
committerTobias Brunner <tobias@strongswan.org>2012-05-02 14:45:38 +0200
commitead92870b8645af72fae75b7f5c0c3475b327380 (patch)
tree8f4410ee338a64f5e69352513d5aab8fd49c7065 /src/libcharon/control/controller.c
parentd724fcd6240b56359fede1ff6ecd7f0c576dbd0d (diff)
downloadstrongswan-ead92870b8645af72fae75b7f5c0c3475b327380.tar.bz2
strongswan-ead92870b8645af72fae75b7f5c0c3475b327380.tar.xz
Loggers specify what log messages they want to receive during registration.
This also allows us to generate the log message only once for all loggers that need it (avoids calls to custom printf specifier callbacks). To update the log levels loggers can simply be registered again.
Diffstat (limited to 'src/libcharon/control/controller.c')
-rw-r--r--src/libcharon/control/controller.c19
1 files changed, 15 insertions, 4 deletions
diff --git a/src/libcharon/control/controller.c b/src/libcharon/control/controller.c
index 7ba4747ac..c23bf044e 100644
--- a/src/libcharon/control/controller.c
+++ b/src/libcharon/control/controller.c
@@ -1,5 +1,5 @@
/*
- * Copyright (C) 2011 Tobias Brunner
+ * Copyright (C) 2011-2012 Tobias Brunner
* Copyright (C) 2007-2011 Martin Willi
* Copyright (C) 2011 revosec AG
* Hochschule fuer Technik Rapperswil
@@ -199,11 +199,11 @@ static bool wait_for_listener(interface_listener_t *listener, job_t *job,
METHOD(logger_t, listener_log, void,
interface_logger_t *this, debug_t group, level_t level, int thread,
- ike_sa_t *ike_sa, char* format, va_list args)
+ ike_sa_t *ike_sa, char* message)
{
if (this->listener->ike_sa == ike_sa)
{
- if (!this->callback(this->param, group, level, ike_sa, format, args))
+ if (!this->callback(this->param, group, level, ike_sa, message))
{
this->listener->status = NEED_MORE;
listener_done(this->listener);
@@ -211,6 +211,14 @@ METHOD(logger_t, listener_log, void,
}
}
+METHOD(logger_t, listener_get_level, level_t,
+ interface_logger_t *this, debug_t group)
+{
+ /* in order to allow callback listeners to decide what they want to log
+ * we request any log message, but only if we actually want logging */
+ return this->callback == controller_cb_empty ? LEVEL_SILENT : LEVEL_PRIVATE;
+}
+
METHOD(job_t, get_priority_medium, job_priority_t,
job_t *this)
{
@@ -350,6 +358,7 @@ METHOD(controller_t, initiate, status_t,
.logger = {
.public = {
.log = _listener_log,
+ .get_level = _listener_get_level,
},
.callback = callback,
.param = param,
@@ -416,6 +425,7 @@ METHOD(controller_t, terminate_ike, status_t,
.logger = {
.public = {
.log = _listener_log,
+ .get_level = _listener_get_level,
},
.callback = callback,
.param = param,
@@ -494,6 +504,7 @@ METHOD(controller_t, terminate_child, status_t,
.logger = {
.public = {
.log = _listener_log,
+ .get_level = _listener_get_level,
},
.callback = callback,
.param = param,
@@ -560,7 +571,7 @@ METHOD(controller_t, terminate_child, status_t,
* See header
*/
bool controller_cb_empty(void *param, debug_t group, level_t level,
- ike_sa_t *ike_sa, char *format, va_list args)
+ ike_sa_t *ike_sa, char *message)
{
return TRUE;
}