mirror of
https://github.com/kakwa/uts-server
synced 2025-01-25 04:47:26 +01:00
add handling of NULL strings in logs
replace NULL char * by const char * "<undef>" in log messages as printf("%s", NULL) behavior is not formalized.
This commit is contained in:
parent
1d7c9cd588
commit
822b97a035
@ -16,6 +16,7 @@ void log_hex(rfc3161_context *ct, int priority, char *id,
|
|||||||
int set_params(rfc3161_context *ct, char *conf_file, char *conf_wd);
|
int set_params(rfc3161_context *ct, char *conf_file, char *conf_wd);
|
||||||
static char *rand_string(char *str, size_t size);
|
static char *rand_string(char *str, size_t size);
|
||||||
void free_uts_context(rfc3161_context *ct);
|
void free_uts_context(rfc3161_context *ct);
|
||||||
|
const char *null_undef(const char * in);
|
||||||
|
|
||||||
// some global variable to handle signals
|
// some global variable to handle signals
|
||||||
int g_uts_sig_up;
|
int g_uts_sig_up;
|
||||||
|
@ -54,20 +54,20 @@ void log_request_debug(const struct mg_request_info *request_info,
|
|||||||
for (int i = 0; i < request_info->num_headers; i++) {
|
for (int i = 0; i < request_info->num_headers; i++) {
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], Header[%s]: %s",
|
uts_logger(context, LOG_DEBUG, "Request[%s], Header[%s]: %s",
|
||||||
request_id, request_info->http_headers[i].name,
|
request_id, request_info->http_headers[i].name,
|
||||||
request_info->http_headers[i].value);
|
null_undef(request_info->http_headers[i].value));
|
||||||
}
|
}
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], request_method: %s",
|
uts_logger(context, LOG_DEBUG, "Request[%s], request_method: %s",
|
||||||
request_id, request_info->request_method);
|
request_id, null_undef(request_info->request_method));
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], request_uri: %s", request_id,
|
uts_logger(context, LOG_DEBUG, "Request[%s], request_uri: %s", request_id,
|
||||||
request_info->request_uri);
|
null_undef(request_info->request_uri));
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], local_uri: %s", request_id,
|
uts_logger(context, LOG_DEBUG, "Request[%s], local_uri: %s", request_id,
|
||||||
request_info->local_uri);
|
null_undef(request_info->local_uri));
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], http_version: %s", request_id,
|
uts_logger(context, LOG_DEBUG, "Request[%s], http_version: %s", request_id,
|
||||||
request_info->http_version);
|
null_undef(request_info->http_version));
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], query_string: %s", request_id,
|
uts_logger(context, LOG_DEBUG, "Request[%s], query_string: %s", request_id,
|
||||||
request_info->query_string);
|
null_undef(request_info->query_string));
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], remote_addr: %s", request_id,
|
uts_logger(context, LOG_DEBUG, "Request[%s], remote_addr: %s", request_id,
|
||||||
request_info->remote_addr);
|
null_undef(request_info->remote_addr));
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], is_ssl: %d", request_id,
|
uts_logger(context, LOG_DEBUG, "Request[%s], is_ssl: %d", request_id,
|
||||||
request_info->is_ssl);
|
request_info->is_ssl);
|
||||||
uts_logger(context, LOG_DEBUG, "Request[%s], content_length: %d",
|
uts_logger(context, LOG_DEBUG, "Request[%s], content_length: %d",
|
||||||
@ -97,9 +97,10 @@ void log_request(const struct mg_request_info *request_info, char *request_id,
|
|||||||
uts_logger(context, LOG_INFO, "Request[%s], remote_addr[%s] ssl[%d] "
|
uts_logger(context, LOG_INFO, "Request[%s], remote_addr[%s] ssl[%d] "
|
||||||
"uri[%s] http_resp_code[%d] duration[%d us] "
|
"uri[%s] http_resp_code[%d] duration[%d us] "
|
||||||
"user-agent[%s] content-type[%s]",
|
"user-agent[%s] content-type[%s]",
|
||||||
request_id, request_info->remote_addr, request_info->is_ssl,
|
request_id, null_undef(request_info->remote_addr),
|
||||||
request_info->local_uri, response_code, timer, user_agent,
|
request_info->is_ssl, null_undef(request_info->local_uri),
|
||||||
content_type);
|
response_code, timer, null_undef(user_agent),
|
||||||
|
null_undef(content_type));
|
||||||
}
|
}
|
||||||
|
|
||||||
// This function will be called by civetweb on every new request.
|
// This function will be called by civetweb on every new request.
|
||||||
|
@ -202,6 +202,12 @@ void uts_logger(rfc3161_context *ct, int priority, char *fmt, ...) {
|
|||||||
free(out);
|
free(out);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char *null_undef(const char * in){
|
||||||
|
if(in == NULL)
|
||||||
|
return "<undef>";
|
||||||
|
return in;
|
||||||
|
}
|
||||||
|
|
||||||
// OpenSSL file openner (use for opening the configuration file
|
// OpenSSL file openner (use for opening the configuration file
|
||||||
static BIO *bio_open_default(rfc3161_context *ct, const char *filename,
|
static BIO *bio_open_default(rfc3161_context *ct, const char *filename,
|
||||||
int format) {
|
int format) {
|
||||||
@ -281,7 +287,7 @@ int set_params(rfc3161_context *ct, char *conf_file, char *conf_wd) {
|
|||||||
if (value == NULL) {
|
if (value == NULL) {
|
||||||
uts_logger(ct, LOG_NOTICE,
|
uts_logger(ct, LOG_NOTICE,
|
||||||
"configuration param['%s'] not set, using default: '%s'",
|
"configuration param['%s'] not set, using default: '%s'",
|
||||||
name, default_value);
|
name, null_undef(default_value));
|
||||||
value = default_value;
|
value = default_value;
|
||||||
}
|
}
|
||||||
switch (type) {
|
switch (type) {
|
||||||
@ -307,11 +313,11 @@ int set_params(rfc3161_context *ct, char *conf_file, char *conf_wd) {
|
|||||||
if (value == NULL) {
|
if (value == NULL) {
|
||||||
uts_logger(ct, LOG_NOTICE,
|
uts_logger(ct, LOG_NOTICE,
|
||||||
"configuration param['%s'] not set, using default: '%s'",
|
"configuration param['%s'] not set, using default: '%s'",
|
||||||
name, default_value);
|
name, null_undef(default_value));
|
||||||
value = default_value;
|
value = default_value;
|
||||||
}
|
}
|
||||||
uts_logger(ct, LOG_DEBUG, "configuration param['%s'] = '%s'", name,
|
uts_logger(ct, LOG_DEBUG, "configuration param['%s'] = '%s'", name,
|
||||||
value);
|
null_undef(value));
|
||||||
switch (type) {
|
switch (type) {
|
||||||
// if it's an http (civetweb) option, put it in the http_options buffer
|
// if it's an http (civetweb) option, put it in the http_options buffer
|
||||||
// like civetweb is expected it.
|
// like civetweb is expected it.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user