Add time to log prefix
This commit is contained in:
@ -17,6 +17,8 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
// TODO use pipes for stdin, stdout, stderr in FastCGI
|
||||||
|
|
||||||
char *fastcgi_add_param(char *buf, const char *key, const char *value) {
|
char *fastcgi_add_param(char *buf, const char *key, const char *value) {
|
||||||
char *ptr = buf;
|
char *ptr = buf;
|
||||||
unsigned long key_len = strlen(key);
|
unsigned long key_len = strlen(key);
|
||||||
|
@ -408,9 +408,9 @@ const char *http_get_status_color(status_code_t status_code) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
char *http_format_date(time_t time, char *buf, size_t size) {
|
char *http_format_date(time_t ts, char *buf, size_t size) {
|
||||||
struct tm time_info;
|
struct tm time_info;
|
||||||
strftime(buf, size, "%a, %d %b %Y %H:%M:%S GMT", gmtime_r(&time, &time_info));
|
strftime(buf, size, "%a, %d %b %Y %H:%M:%S GMT", gmtime_r(&ts, &time_info));
|
||||||
return buf;
|
return buf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -109,7 +109,7 @@ long sock_send(sock *s, void *buf, unsigned long len, int flags) {
|
|||||||
long sock_send_x(sock *s, void *buf, unsigned long len, int flags) {
|
long sock_send_x(sock *s, void *buf, unsigned long len, int flags) {
|
||||||
long sent = 0;
|
long sent = 0;
|
||||||
for (long ret; sent < len; sent += ret) {
|
for (long ret; sent < len; sent += ret) {
|
||||||
ret = sock_send(s, buf + sent, len - sent, flags);
|
ret = sock_send(s, (unsigned char *) buf + sent, len - sent, flags);
|
||||||
if (ret <= 0)
|
if (ret <= 0)
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
27
src/logger.c
27
src/logger.c
@ -24,10 +24,13 @@
|
|||||||
#define LOG_NAME_LEN 12
|
#define LOG_NAME_LEN 12
|
||||||
#define LOG_PREFIX_LEN 256
|
#define LOG_PREFIX_LEN 256
|
||||||
|
|
||||||
#define LOG_PREFIX "[%-8s][%-6s]"
|
#define LOG_PREFIX "[%8s][%-8s][%-6s]"
|
||||||
|
#define LOG_TIME_BUF_SIZE 9
|
||||||
|
#define LOG_TIME_FMT "%H:%M:%S"
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
log_lvl_t lvl;
|
log_lvl_t lvl;
|
||||||
|
long time;
|
||||||
char name[LOG_NAME_LEN];
|
char name[LOG_NAME_LEN];
|
||||||
char prefix[LOG_PREFIX_LEN];
|
char prefix[LOG_PREFIX_LEN];
|
||||||
char txt[LOG_MAX_MSG_SIZE];
|
char txt[LOG_MAX_MSG_SIZE];
|
||||||
@ -58,14 +61,20 @@ static const char *level_keywords[] = {
|
|||||||
"DEBUG"
|
"DEBUG"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static const char *timestr(time_t ts, char *buf) {
|
||||||
|
struct tm time_info;
|
||||||
|
strftime(buf, LOG_TIME_BUF_SIZE, LOG_TIME_FMT, localtime_r(&ts, &time_info));
|
||||||
|
return buf;
|
||||||
|
}
|
||||||
|
|
||||||
static void err(const char *restrict msg) {
|
static void err(const char *restrict msg) {
|
||||||
char err_buf[64];
|
char err_buf[64], time_buf[LOG_TIME_BUF_SIZE];
|
||||||
fprintf(stderr, ERR_STR LOG_PREFIX " %s: %s" CLR_STR "\n", "logger",
|
fprintf(stderr, ERR_STR LOG_PREFIX " %s: %s" CLR_STR "\n", timestr(time(NULL), time_buf), "logger",
|
||||||
level_keywords[LOG_CRITICAL], msg, error_str(errno, err_buf, sizeof(err_buf)));
|
level_keywords[LOG_CRITICAL], msg, error_str(errno, err_buf, sizeof(err_buf)));
|
||||||
}
|
}
|
||||||
|
|
||||||
void logmsgf(log_lvl_t level, const char *restrict format, ...) {
|
void logmsgf(log_lvl_t level, const char *restrict format, ...) {
|
||||||
char buf[256], err_buf[256];
|
char buf[256], err_buf[256], time_buf[LOG_TIME_BUF_SIZE];
|
||||||
va_list args;
|
va_list args;
|
||||||
va_start(args, format);
|
va_start(args, format);
|
||||||
|
|
||||||
@ -84,7 +93,11 @@ void logmsgf(log_lvl_t level, const char *restrict format, ...) {
|
|||||||
if (!alive) {
|
if (!alive) {
|
||||||
// no logger thread running
|
// no logger thread running
|
||||||
// simply write to stdout without synchronization
|
// simply write to stdout without synchronization
|
||||||
printf("%s" LOG_PREFIX "%s%s ", color, (name != NULL) ? (char *) name : "", level_keywords[level], CLR_STR, (prefix != NULL) ? (char *) prefix : "");
|
printf("%s" LOG_PREFIX "%s%s ", color,
|
||||||
|
timestr(time(NULL), time_buf),
|
||||||
|
(name != NULL) ? (char *) name : "",
|
||||||
|
level_keywords[level], CLR_STR,
|
||||||
|
(prefix != NULL) ? (char *) prefix : "");
|
||||||
vprintf(buf, args);
|
vprintf(buf, args);
|
||||||
printf("\n");
|
printf("\n");
|
||||||
} else {
|
} else {
|
||||||
@ -125,6 +138,7 @@ void logmsgf(log_lvl_t level, const char *restrict format, ...) {
|
|||||||
|
|
||||||
vsnprintf(msg->txt, sizeof(msg->txt), buf, args);
|
vsnprintf(msg->txt, sizeof(msg->txt), buf, args);
|
||||||
msg->lvl = level;
|
msg->lvl = level;
|
||||||
|
msg->time = time(NULL);
|
||||||
|
|
||||||
if (name != NULL) {
|
if (name != NULL) {
|
||||||
snprintf(msg->name, sizeof(msg->name), "%s", (char *) name);
|
snprintf(msg->name, sizeof(msg->name), "%s", (char *) name);
|
||||||
@ -220,6 +234,8 @@ void logger_set_prefix(const char *restrict format, ...) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void *logger_thread(void *arg) {
|
static void *logger_thread(void *arg) {
|
||||||
|
char time_buf[LOG_TIME_BUF_SIZE];
|
||||||
|
|
||||||
logger_set_name("logger");
|
logger_set_name("logger");
|
||||||
alive = 1;
|
alive = 1;
|
||||||
|
|
||||||
@ -241,6 +257,7 @@ static void *logger_thread(void *arg) {
|
|||||||
|
|
||||||
printf("%s" LOG_PREFIX "%s%s %s\n",
|
printf("%s" LOG_PREFIX "%s%s %s\n",
|
||||||
(msg->lvl <= LOG_ERROR) ? ERR_STR : ((msg->lvl <= LOG_WARNING) ? WRN_STR : ""),
|
(msg->lvl <= LOG_ERROR) ? ERR_STR : ((msg->lvl <= LOG_WARNING) ? WRN_STR : ""),
|
||||||
|
(timestr(msg->time, time_buf)),
|
||||||
(msg->name[0] != 0) ? (char *) msg->name : "", level_keywords[msg->lvl], CLR_STR,
|
(msg->name[0] != 0) ? (char *) msg->name : "", level_keywords[msg->lvl], CLR_STR,
|
||||||
(msg->prefix[0] != 0) ? (char *) msg->prefix : "", msg->txt);
|
(msg->prefix[0] != 0) ? (char *) msg->prefix : "", msg->txt);
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user