From 3fc4e6b9300d231018c9a66ae4bc7b424e1617db Mon Sep 17 00:00:00 2001 From: ekoby <7406535+ekoby@users.noreply.github.com> Date: Fri, 11 Dec 2020 15:15:00 -0500 Subject: [PATCH] do not relay on uv_now() to supply correct time (#204) --- library/utils.c | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/library/utils.c b/library/utils.c index 8a65964c..f6c831e9 100644 --- a/library/utils.c +++ b/library/utils.c @@ -119,7 +119,6 @@ static uv_loop_t *ts_loop; static uint64_t starttime; static uint64_t last_update; static char elapsed_buffer[32]; -static uint64_t clock_offset; static uv_prepare_t log_flusher; static log_writer logger = NULL; @@ -175,9 +174,6 @@ static void init_debug(uv_loop_t *loop) { ziti_debug_out = stderr; starttime = uv_now(loop); - uv_timeval64_t clock; - uv_gettimeofday(&clock); - clock_offset = (clock.tv_sec * 1000 + clock.tv_usec / 1000) - starttime; // in millis uv_prepare_init(loop, &log_flusher); uv_unref((uv_handle_t *) &log_flusher); @@ -242,21 +238,19 @@ static const char *get_utc_time() { uint64_t now = uv_now(ts_loop); if (now > last_update) { last_update = now; - uint64_t realtime = clock_offset + now; - time_t time = realtime / 1000; // seconds - time_t millis = realtime % 1000; - struct tm *tm = gmtime(&time); - snprintf(elapsed_buffer, sizeof(elapsed_buffer), "%04d-%02d-%02dT%02d:%02d:%02d.%03ldZ", + uv_timeval64_t ts; + uv_gettimeofday(&ts); + struct tm *tm = gmtime(&ts.tv_sec); + + snprintf(elapsed_buffer, sizeof(elapsed_buffer), "%04d-%02d-%02dT%02d:%02d:%02d.%03dZ", 1900 + tm->tm_year, tm->tm_mon + 1, tm->tm_mday, - tm->tm_hour, tm->tm_min, tm->tm_sec, millis + tm->tm_hour, tm->tm_min, tm->tm_sec, ts.tv_usec / 1000 ); } return elapsed_buffer; } -static char errbuf[1024]; - void ziti_alloc_cb(uv_handle_t *handle, size_t suggested_size, uv_buf_t *buf) { buf->base = (char *) malloc(suggested_size); if (buf->base == NULL) {