/* SPDX-License-Identifier: MIT Copyright (c) 2023 John Watts and the LuminaSensum contributors */ #include "Clock.h" #include "mbed.h" using namespace std::chrono; void clock_setup(void) { // mbed reads the RTC at boot, do nothing for now } microseconds clock_now(void) { time_t now_seconds = time(NULL); microseconds microsecs = seconds(now_seconds); return microsecs; } SNTPError clock_sync(NetworkInterface &net) { struct timeval time; SNTPError err; err = sntp(net, "time.google.com", 123, &time); if (err != SNTPSuccess) { return err; } set_time(time.tv_sec); return SNTPSuccess; } const char *clock_timestring(microseconds time, const char *format) { time_t time_seconds = ceil<seconds>(time).count(); struct tm *local_time = localtime(&time_seconds); static char buffer[64]; size_t buffer_size = sizeof(buffer); size_t buffer_written; buffer_written = strftime(buffer, buffer_size, format, local_time); if (buffer_written == 0) { // It overflowed, so return something useful return "(time overflow)"; } else { return buffer; } } const char *clock_iso8601string(microseconds time) { const char *timestring = clock_timestring(time, "%Y-%m-%dT%H:%M:%S"); long only_microseconds = time.count() % 1000000; static char buffer[128]; int buffer_size = sizeof(buffer); int written; written = snprintf( buffer, buffer_size, "%s.%06li", timestring, only_microseconds); if (written >= buffer_size) { // It overflowed, so return something useful return "(iso8601 overflow)"; } else { return buffer; } } const char *clock_iso8601string_now(void) { microseconds now = clock_now(); return clock_iso8601string(clock_now()); }