Files
ttgo_smartwatch_prox/src/hardware/timesync.cpp
2020-08-18 09:52:36 +02:00

199 lines
6.5 KiB
C++

/****************************************************************************
* Tu May 22 21:23:51 2020
* Copyright 2020 Dirk Brosswick
* Email: dirk.brosswick@googlemail.com
****************************************************************************/
/*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#include "config.h"
#include "TTGO.h"
#include "time.h"
#include "wifictl.h"
#include "config.h"
#include "timesync.h"
#include "powermgm.h"
#include "json_psram_allocator.h"
EventGroupHandle_t time_event_handle = NULL;
TaskHandle_t _timesync_Task;
void timesync_Task( void * pvParameters );
timesync_config_t timesync_config;
void timesync_wifictl_event_cb( EventBits_t event, char* msg );
void timesync_setup( TTGOClass *ttgo ) {
timesync_read_config();
time_event_handle = xEventGroupCreate();
wifictl_register_cb( WIFICTL_CONNECT, timesync_wifictl_event_cb );
}
void timesync_wifictl_event_cb( EventBits_t event, char* msg ) {
log_i("timesync wifictl event: %04x", event );
switch ( event ) {
case WIFICTL_CONNECT: if ( timesync_config.timesync ) {
if ( xEventGroupGetBits( time_event_handle ) & TIME_SYNC_REQUEST ) {
return;
}
else {
xEventGroupSetBits( time_event_handle, TIME_SYNC_REQUEST );
xTaskCreate( timesync_Task, /* Function to implement the task */
"timesync Task", /* Name of the task */
2000, /* Stack size in words */
NULL, /* Task input parameter */
1, /* Priority of the task */
&_timesync_Task ); /* Task handle. */
}
}
break;
}
}
void timesync_save_config( void ) {
if ( SPIFFS.exists( TIMESYNC_CONFIG_FILE ) ) {
SPIFFS.remove( TIMESYNC_CONFIG_FILE );
log_i("remove old binary timesync config");
}
fs::File file = SPIFFS.open( TIMESYNC_JSON_CONFIG_FILE, FILE_WRITE );
if (!file) {
log_e("Can't open file: %s!", TIMESYNC_JSON_CONFIG_FILE );
}
else {
SpiRamJsonDocument doc( 1000 );
doc["daylightsave"] = timesync_config.daylightsave;
doc["timesync"] = timesync_config.timesync;
doc["timezone"] = timesync_config.timezone;
if ( serializeJsonPretty( doc, file ) == 0) {
log_e("Failed to write config file");
}
doc.clear();
}
file.close();
}
void timesync_read_config( void ) {
if ( SPIFFS.exists( TIMESYNC_JSON_CONFIG_FILE ) ) {
fs::File file = SPIFFS.open( TIMESYNC_JSON_CONFIG_FILE, FILE_READ );
if (!file) {
log_e("Can't open file: %s!", TIMESYNC_JSON_CONFIG_FILE );
}
else {
int filesize = file.size();
SpiRamJsonDocument doc( filesize * 2 );
DeserializationError error = deserializeJson( doc, file );
if ( error ) {
log_e("update check deserializeJson() failed: %s", error.c_str() );
}
else {
timesync_config.daylightsave = doc["daylightsave"].as<bool>();
timesync_config.timesync = doc["timesync"].as<bool>();
timesync_config.timezone = doc["timezone"].as<uint32_t>();
}
doc.clear();
}
file.close();
}
else {
log_i("no json config exists, read from binary");
fs::File file = SPIFFS.open( TIMESYNC_CONFIG_FILE, FILE_READ );
if (!file) {
log_e("Can't open file: %s!", TIMESYNC_CONFIG_FILE );
}
else {
int filesize = file.size();
if ( filesize > sizeof( timesync_config ) ) {
log_e("Failed to read configfile. Wrong filesize!" );
}
else {
file.read( (uint8_t *)&timesync_config, filesize );
file.close();
timesync_save_config();
return;
}
file.close();
}
}
}
bool timesync_get_timesync( void ) {
return( timesync_config.timesync );
}
void timesync_set_timesync( bool timesync ) {
timesync_config.timesync = timesync;
timesync_save_config();
}
bool timesync_get_daylightsave( void ) {
return( timesync_config.daylightsave );
}
void timesync_set_daylightsave( bool daylightsave ) {
timesync_config.daylightsave = daylightsave;
timesync_save_config();
}
int32_t timesync_get_timezone( void ) {
return( timesync_config.timezone );
}
void timesync_set_timezone( int32_t timezone ) {
timesync_config.timezone = timezone;
timesync_save_config();
}
void timesyncToSystem( void ) {
TTGOClass *ttgo = TTGOClass::getWatch();
ttgo->rtc->syncToSystem();
}
void timesyncToRTC( void ) {
TTGOClass *ttgo = TTGOClass::getWatch();
ttgo->rtc->syncToRtc();
}
void timesync_Task( void * pvParameters ) {
log_i("start time sync task");
if ( xEventGroupGetBits( time_event_handle ) & TIME_SYNC_REQUEST ) {
struct tm info;
long gmtOffset_sec = timesync_config.timezone * 3600;
int daylightOffset_sec = 0;
if ( timesync_config.daylightsave )
daylightOffset_sec = 3600;
configTime( gmtOffset_sec, daylightOffset_sec, "pool.ntp.org" );
if( !getLocalTime( &info ) ) {
log_e("Failed to obtain time" );
}
}
xEventGroupClearBits( time_event_handle, TIME_SYNC_REQUEST );
vTaskDelete( NULL );
}