daemon: Use separate method to set default loggers
This way it is not necessary to pass the same values to reload the loggers.
This commit is contained in:
parent
ff22d53ba9
commit
9665686bd8
|
@ -39,11 +39,6 @@
|
|||
*/
|
||||
static level_t default_loglevel = LEVEL_CTRL;
|
||||
|
||||
/**
|
||||
* Loglevel configuration
|
||||
*/
|
||||
static level_t levels[DBG_MAX];
|
||||
|
||||
/**
|
||||
* Connection to initiate
|
||||
*/
|
||||
|
@ -129,7 +124,7 @@ static int run()
|
|||
"configuration");
|
||||
if (lib->settings->load_files(lib->settings, lib->conf, FALSE))
|
||||
{
|
||||
charon->load_loggers(charon, levels, TRUE);
|
||||
charon->load_loggers(charon);
|
||||
lib->plugins->reload(lib->plugins, NULL);
|
||||
}
|
||||
else
|
||||
|
@ -311,6 +306,7 @@ int main(int argc, char *argv[])
|
|||
{
|
||||
struct sigaction action;
|
||||
struct utsname utsname;
|
||||
level_t levels[DBG_MAX];
|
||||
int group;
|
||||
|
||||
/* handle simple arguments */
|
||||
|
@ -338,7 +334,8 @@ int main(int argc, char *argv[])
|
|||
{
|
||||
levels[group] = default_loglevel;
|
||||
}
|
||||
charon->load_loggers(charon, levels, TRUE);
|
||||
charon->set_default_loggers(charon, levels, TRUE);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
if (!lookup_uid_gid())
|
||||
{
|
||||
|
|
|
@ -192,7 +192,7 @@ int main(int argc, char *argv[])
|
|||
lib->settings->set_int(lib->settings, "charon-nm.syslog.daemon.default",
|
||||
lib->settings->get_int(lib->settings,
|
||||
"charon-nm.syslog.daemon.default", 1));
|
||||
charon->load_loggers(charon, NULL, FALSE);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
/* use random ports to avoid conflicts with regular charon */
|
||||
lib->settings->set_int(lib->settings, "charon-nm.port", 0);
|
||||
|
|
|
@ -220,7 +220,8 @@ static void init_and_run(DWORD dwArgc, LPTSTR *lpszArgv, int (*wait)())
|
|||
update_status(SERVICE_START_PENDING);
|
||||
if (libcharon_init())
|
||||
{
|
||||
charon->load_loggers(charon, levels, TRUE);
|
||||
charon->set_default_loggers(charon, levels, TRUE);
|
||||
charon->load_loggers(charon);
|
||||
print_version();
|
||||
update_status(SERVICE_START_PENDING);
|
||||
if (charon->initialize(charon, PLUGINS))
|
||||
|
|
|
@ -269,7 +269,7 @@ static int run()
|
|||
"configuration");
|
||||
if (lib->settings->load_files(lib->settings, lib->conf, FALSE))
|
||||
{
|
||||
charon->load_loggers(charon, NULL, FALSE);
|
||||
charon->load_loggers(charon);
|
||||
lib->plugins->reload(lib->plugins, NULL);
|
||||
}
|
||||
else
|
||||
|
@ -390,7 +390,7 @@ int main(int argc, char *argv[])
|
|||
sd_notifyf(0, "STATUS=unknown uid/gid");
|
||||
return SS_RC_INITIALIZATION_FAILED;
|
||||
}
|
||||
charon->load_loggers(charon, NULL, FALSE);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
lib->plugins->add_static_features(lib->plugins, lib->ns, features,
|
||||
countof(features), TRUE, journal_reload, &journal);
|
||||
|
|
|
@ -275,7 +275,7 @@ int main(int argc, char *argv[])
|
|||
lib->settings->set_int(lib->settings, "%s.syslog.daemon.default",
|
||||
lib->settings->get_int(lib->settings, "%s.syslog.daemon.default", 1,
|
||||
dmn_name), dmn_name);
|
||||
charon->load_loggers(charon, NULL, FALSE);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
DBG1(DBG_DMN, "Starting charon with TKM backend (strongSwan "VERSION")");
|
||||
|
||||
|
|
|
@ -52,7 +52,7 @@ static bool test_runner_init(bool init)
|
|||
libcharon_init();
|
||||
lib->settings->set_int(lib->settings,
|
||||
"test-runner.filelog.stdout.default", 0);
|
||||
charon->load_loggers(charon, NULL, FALSE);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
/* Register TKM specific plugins */
|
||||
static plugin_feature_t features[] = {
|
||||
|
|
|
@ -58,16 +58,6 @@
|
|||
*/
|
||||
static FILE *pidfile = NULL;
|
||||
|
||||
/**
|
||||
* Log levels as defined via command line arguments
|
||||
*/
|
||||
static level_t levels[DBG_MAX];
|
||||
|
||||
/**
|
||||
* Whether to only use syslog when logging
|
||||
*/
|
||||
static bool use_syslog = FALSE;
|
||||
|
||||
/**
|
||||
* hook in library for debugging messages
|
||||
*/
|
||||
|
@ -126,7 +116,7 @@ static void run()
|
|||
"configuration");
|
||||
if (lib->settings->load_files(lib->settings, lib->conf, FALSE))
|
||||
{
|
||||
charon->load_loggers(charon, levels, !use_syslog);
|
||||
charon->load_loggers(charon);
|
||||
lib->plugins->reload(lib->plugins, NULL);
|
||||
}
|
||||
else
|
||||
|
@ -289,6 +279,8 @@ int main(int argc, char *argv[])
|
|||
struct sigaction action;
|
||||
int group, status = SS_RC_INITIALIZATION_FAILED;
|
||||
struct utsname utsname;
|
||||
level_t levels[DBG_MAX];
|
||||
bool use_syslog = FALSE;
|
||||
|
||||
/* logging for library during initialization, as we have no bus yet */
|
||||
dbg = dbg_stderr;
|
||||
|
@ -382,7 +374,8 @@ int main(int argc, char *argv[])
|
|||
goto deinit;
|
||||
}
|
||||
|
||||
charon->load_loggers(charon, levels, !use_syslog);
|
||||
charon->set_default_loggers(charon, levels, !use_syslog);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
if (uname(&utsname) != 0)
|
||||
{
|
||||
|
|
|
@ -624,7 +624,7 @@ JNI_METHOD(CharonVpnService, initializeCharon, jboolean,
|
|||
return FALSE;
|
||||
}
|
||||
|
||||
charon->load_loggers(charon, NULL, FALSE);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
charonservice_init(env, this, builder, byod);
|
||||
|
||||
|
|
|
@ -41,11 +41,6 @@ void dispatcher_cleanup()
|
|||
DESTROY_IF(dispatcher);
|
||||
}
|
||||
|
||||
/**
|
||||
* Loglevel configuration
|
||||
*/
|
||||
static level_t levels[DBG_MAX];
|
||||
|
||||
/**
|
||||
* hook in library for debugging messages
|
||||
*/
|
||||
|
@ -154,6 +149,7 @@ int main(int argc, char *argv[])
|
|||
{
|
||||
struct sigaction action;
|
||||
struct utsname utsname;
|
||||
level_t levels[DBG_MAX];
|
||||
int group;
|
||||
|
||||
dbg = dbg_stderr;
|
||||
|
@ -178,7 +174,8 @@ int main(int argc, char *argv[])
|
|||
{
|
||||
levels[group] = LEVEL_CTRL;
|
||||
}
|
||||
charon->load_loggers(charon, levels, TRUE);
|
||||
charon->set_default_loggers(charon, levels, TRUE);
|
||||
charon->load_loggers(charon);
|
||||
|
||||
lib->settings->set_default_str(lib->settings, "charon-xpc.port", "0");
|
||||
lib->settings->set_default_str(lib->settings, "charon-xpc.port_nat_t", "0");
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (C) 2006-2016 Tobias Brunner
|
||||
* Copyright (C) 2006-2017 Tobias Brunner
|
||||
* Copyright (C) 2005-2009 Martin Willi
|
||||
* Copyright (C) 2006 Daniel Roethlisberger
|
||||
* Copyright (C) 2005 Jan Hutter
|
||||
|
@ -86,6 +86,16 @@ struct private_daemon_t {
|
|||
*/
|
||||
linked_list_t *loggers;
|
||||
|
||||
/**
|
||||
* Cached log levels for default loggers
|
||||
*/
|
||||
level_t *levels;
|
||||
|
||||
/**
|
||||
* Whether to log to stdout/err by default
|
||||
*/
|
||||
bool to_stderr;
|
||||
|
||||
/**
|
||||
* Identifier used for syslog (in the openlog call)
|
||||
*/
|
||||
|
@ -532,7 +542,7 @@ static void load_custom_logger(private_daemon_t *this,
|
|||
}
|
||||
|
||||
METHOD(daemon_t, load_loggers, void,
|
||||
private_daemon_t *this, level_t levels[DBG_MAX], bool to_stderr)
|
||||
private_daemon_t *this)
|
||||
{
|
||||
enumerator_t *enumerator;
|
||||
linked_list_t *current_loggers;
|
||||
|
@ -564,7 +574,7 @@ METHOD(daemon_t, load_loggers, void,
|
|||
load_custom_logger(this, &custom_loggers[i], current_loggers);
|
||||
}
|
||||
|
||||
if (!this->loggers->get_count(this->loggers) && levels)
|
||||
if (!this->loggers->get_count(this->loggers) && this->levels)
|
||||
{ /* setup legacy style default loggers configured via command-line */
|
||||
file_logger_t *file_logger;
|
||||
sys_logger_t *sys_logger;
|
||||
|
@ -578,11 +588,11 @@ METHOD(daemon_t, load_loggers, void,
|
|||
{
|
||||
if (sys_logger)
|
||||
{
|
||||
sys_logger->set_level(sys_logger, group, levels[group]);
|
||||
sys_logger->set_level(sys_logger, group, this->levels[group]);
|
||||
}
|
||||
if (to_stderr)
|
||||
if (this->to_stderr)
|
||||
{
|
||||
file_logger->set_level(file_logger, group, levels[group]);
|
||||
file_logger->set_level(file_logger, group, this->levels[group]);
|
||||
}
|
||||
}
|
||||
if (sys_logger)
|
||||
|
@ -604,13 +614,39 @@ METHOD(daemon_t, load_loggers, void,
|
|||
this->mutex->unlock(this->mutex);
|
||||
}
|
||||
|
||||
METHOD(daemon_t, set_default_loggers, void,
|
||||
private_daemon_t *this, level_t levels[DBG_MAX], bool to_stderr)
|
||||
{
|
||||
debug_t group;
|
||||
|
||||
this->mutex->lock(this->mutex);
|
||||
if (!levels)
|
||||
{
|
||||
free(this->levels);
|
||||
this->levels = NULL;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (!this->levels)
|
||||
{
|
||||
this->levels = calloc(sizeof(level_t), DBG_MAX);
|
||||
}
|
||||
for (group = 0; group < DBG_MAX; group++)
|
||||
{
|
||||
this->levels[group] = levels[group];
|
||||
}
|
||||
this->to_stderr = to_stderr;
|
||||
}
|
||||
this->mutex->unlock(this->mutex);
|
||||
}
|
||||
|
||||
METHOD(daemon_t, set_level, void,
|
||||
private_daemon_t *this, debug_t group, level_t level)
|
||||
{
|
||||
enumerator_t *enumerator;
|
||||
logger_entry_t *entry;
|
||||
|
||||
/* we set the loglevel on ALL sys- and file-loggers */
|
||||
/* we set the loglevel on ALL loggers */
|
||||
this->mutex->lock(this->mutex);
|
||||
enumerator = this->loggers->create_enumerator(this->loggers);
|
||||
while (enumerator->enumerate(enumerator, &entry))
|
||||
|
@ -694,6 +730,7 @@ static void destroy(private_daemon_t *this)
|
|||
DESTROY_IF(this->public.bus);
|
||||
this->loggers->destroy_function(this->loggers, (void*)logger_entry_destroy);
|
||||
this->mutex->destroy(this->mutex);
|
||||
free(this->levels);
|
||||
free(this);
|
||||
}
|
||||
|
||||
|
@ -879,6 +916,7 @@ private_daemon_t *daemon_create()
|
|||
.initialize = _initialize,
|
||||
.start = _start,
|
||||
.load_loggers = _load_loggers,
|
||||
.set_default_loggers = _set_default_loggers,
|
||||
.set_level = _set_level,
|
||||
.bus = bus_create(),
|
||||
},
|
||||
|
|
|
@ -1,5 +1,5 @@
|
|||
/*
|
||||
* Copyright (C) 2006-2012 Tobias Brunner
|
||||
* Copyright (C) 2006-2017 Tobias Brunner
|
||||
* Copyright (C) 2005-2009 Martin Willi
|
||||
* Copyright (C) 2006 Daniel Roethlisberger
|
||||
* Copyright (C) 2005 Jan Hutter
|
||||
|
@ -338,17 +338,27 @@ struct daemon_t {
|
|||
/**
|
||||
* Load/Reload loggers defined in strongswan.conf
|
||||
*
|
||||
* @param levels optional debug levels used to create default loggers
|
||||
* if none are defined in strongswan.conf
|
||||
* @param to_stderr TRUE to log to stderr/stdout if no loggers are defined
|
||||
* in strongswan.conf
|
||||
* If none are defined in strongswan.conf default loggers configured via
|
||||
* set_default_loggers() are loaded.
|
||||
*/
|
||||
void (*load_loggers)(daemon_t *this, level_t levels[DBG_MAX],
|
||||
bool to_stderr);
|
||||
void (*load_loggers)(daemon_t *this);
|
||||
|
||||
/**
|
||||
* Set the log level for the given log group for all configured file-,
|
||||
* syslog and custom-loggers.
|
||||
* Configure default loggers if none are defined in strongswan.conf
|
||||
*
|
||||
* @param levels debug levels used to create default loggers if none are
|
||||
* defined in strongswan.conf (NULL to disable)
|
||||
* @param to_stderr TRUE to log to stderr/stdout if no loggers are defined
|
||||
* in strongswan.conf (logging to syslog is always enabled)
|
||||
*/
|
||||
void (*set_default_loggers)(daemon_t *this, level_t levels[DBG_MAX],
|
||||
bool to_stderr);
|
||||
|
||||
/**
|
||||
* Set the log level for the given log group for all loaded loggers.
|
||||
*
|
||||
* This change is not persistent and gets reset if loggers are reloaded
|
||||
* via load_loggers().
|
||||
*
|
||||
* @param group log group
|
||||
* @param level log level
|
||||
|
|
|
@ -45,7 +45,7 @@ static void initialize_logging()
|
|||
lib->settings->set_int(lib->settings, "%s.filelog.stderr.default",
|
||||
lib->settings->get_int(lib->settings, "%s.filelog.stderr.default",
|
||||
level, lib->ns), lib->ns);
|
||||
charon->load_loggers(charon, NULL, TRUE);
|
||||
charon->load_loggers(charon);
|
||||
}
|
||||
|
||||
static bool test_runner_init(bool init)
|
||||
|
|
|
@ -282,7 +282,7 @@ static void initialize_logging()
|
|||
level, lib->ns), lib->ns);
|
||||
lib->settings->set_bool(lib->settings, "%s.filelog.stderr.ike_name", TRUE,
|
||||
lib->ns);
|
||||
charon->load_loggers(charon, NULL, TRUE);
|
||||
charon->load_loggers(charon);
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue