Hieromon / AutoConnect

An Arduino library for ESP8266/ESP32 WLAN configuration at runtime with the Web interface
https://hieromon.github.io/AutoConnect/
MIT License
908 stars 190 forks source link

timing will not change from home pages #45

Closed Mrtian2 closed 5 years ago

Mrtian2 commented 5 years ago

how to take the timing from the computer or RTC? the home page timing keep remind as 1970/01/01(Thr) 00:04:25. seems it didn't get timing from the website .

Hieromon commented 5 years ago

What do you have a doubt about? Can you confirm the policy before posting the issue?

Mrtian2 commented 5 years ago

oh sorry I didn't notice that
`/* Simple.ino, Example for the AutoConnect library. Copyright (c) 2018, Hieromon Ikasamo https://github.com/Hieromon/AutoConnect

This software is released under the MIT License. https://opensource.org/licenses/MIT */

if defined(ARDUINO_ARCH_ESP8266)

include

include

elif defined(ARDUINO_ARCH_ESP32)

include

include

endif

include

include

static const char AUX_TIMEZONE[] PROGMEM = R"( { "title": "TimeZone", "uri": "/timezone", "menu": true, "element": [ { "name": "caption", "type": "ACText", "value": "Sets the time zone to get the current local time.", "style": "font-family:Arial;font-weight:bold;text-align:center;margin-bottom:10px;color:DarkSlateBlue" }, { "name": "timezone", "type": "ACSelect", "label": "Select TZ name", "option": [] }, { "name": "newline", "type": "ACElement", "value": "
" }, { "name": "start", "type": "ACSubmit", "value": "OK", "uri": "/start" } ] } )";

typedef struct { const char zone; const char ntpServer; int8_t tzoff; } Timezone_t;

static const Timezone_t TZ[] = { { "Europe/London", "europe.pool.ntp.org", 0 }, { "Europe/Berlin", "europe.pool.ntp.org", 1 }, { "Europe/Helsinki", "europe.pool.ntp.org", 2 }, { "Europe/Moscow", "europe.pool.ntp.org", 3 }, { "Asia/Dubai", "asia.pool.ntp.org", 4 }, { "Asia/Karachi", "asia.pool.ntp.org", 5 }, { "Asia/Dhaka", "asia.pool.ntp.org", 6 }, { "Asia/Jakarta", "asia.pool.ntp.org", 7 }, { "Asia/Manila", "asia.pool.ntp.org", 8 }, { "Asia/Tokyo", "asia.pool.ntp.org", 9 }, { "Australia/Brisbane", "oceania.pool.ntp.org", 10 }, { "Pacific/Noumea", "oceania.pool.ntp.org", 11 }, { "Pacific/Auckland", "oceania.pool.ntp.org", 12 }, { "Atlantic/Azores", "europe.pool.ntp.org", -1 }, { "America/Noronha", "south-america.pool.ntp.org", -2 }, { "America/Araguaina", "south-america.pool.ntp.org", -3 }, { "America/Blanc-Sablon", "north-america.pool.ntp.org", -4}, { "America/New_York", "north-america.pool.ntp.org", -5 }, { "America/Chicago", "north-america.pool.ntp.org", -6 }, { "America/Denver", "north-america.pool.ntp.org", -7 }, { "America/Los_Angeles", "north-america.pool.ntp.org", -8 }, { "America/Anchorage", "north-america.pool.ntp.org", -9 }, { "Pacific/Honolulu", "north-america.pool.ntp.org", -10 }, { "Pacific/Samoa", "oceania.pool.ntp.org", -11 } };

if defined(ARDUINO_ARCH_ESP8266)

ESP8266WebServer Server;

elif defined(ARDUINO_ARCH_ESP32)

WebServer Server;

endif

AutoConnect Portal(Server); AutoConnectConfig Config; // Enable autoReconnect supported on v0.9.4 AutoConnectAux Timezone;

void rootPage() { String content = "" "" "<meta name=\"viewport\" content=\"width=device-width, initial-scale=1\">" "" "" "<h2 align=\"center\" style=\"color:blue;margin:20px;\">Hello, world" "<h3 align=\"center\" style=\"color:gray;margin:10px;\">{{DateTime}}" "<p style=\"text-align:center;\">Reload the page to update the time.

" "

<p style=\"padding-top:15px;text-align:center\">" AUTOCONNECT_LINK(COG_24) "

" "" ""; static const char wd[7] = { "Sun","Mon","Tue","Wed","Thr","Fri","Sat" }; struct tm tm; time_t t; char dateTime[26];

t = time(NULL); tm = localtime(&t); sprintf(dateTime, "%04d/%02d/%02d(%s) %02d:%02d:%02d.", tm->tm_year + 1900, tm->tm_mon + 1, tm->tm_mday, wd[tm->tm_wday], tm->tm_hour, tm->tm_min, tm->tm_sec); content.replace("{{DateTime}}", String(dateTime)); Server.send(200, "text/html", content); }

void startPage() { // Retrieve the value of AutoConnectElement with arg function of WebServer class. // Values are accessible with the element name. String tz = Server.arg("timezone");

for (uint8_t n = 0; n < sizeof(TZ) / sizeof(Timezone_t); n++) { String tzName = String(TZ[n].zone); if (tz.equalsIgnoreCase(tzName)) { configTime(TZ[n].tzoff * 3600, 0, TZ[n].ntpServer); Serial.println("Time zone: " + tz); Serial.println("ntp server: " + String(TZ[n].ntpServer)); break; } }

// The /start page just constitutes timezone, // it redirects to the root page without the content response. Server.sendHeader("Location", String("http://") + Server.client().localIP().toString() + String("/")); Server.send(302, "text/plain", ""); Server.client().flush(); Server.client().stop(); }

void setup() { delay(1000); Serial.begin(115200); Serial.println(); Config.apid = "Server for testing"; Config.psk = "Cepl2014";

// Enable saved past credential by autoReconnect option, // even once it is disconnected. // AC_SAVECREDENTIAL_AUTO; Config.autoReconnect = true; Portal.config(Config);

// Load aux. page Timezone.load(AUX_TIMEZONE); // Retrieve the select element that holds the time zone code and // register the zone mnemonic in advance. AutoConnectSelect& tz = Timezone.getElement("timezone"); for (uint8_t n = 0; n < sizeof(TZ) / sizeof(Timezone_t); n++) { tz.add(String(TZ[n].zone)); }

Portal.join({ Timezone }); // Register aux. page

// Behavior a root path of ESP8266WebServer. Server.on("/", rootPage); Server.on("/start", startPage); // Set NTP server trigger handler

// Establish a connection with an autoReconnect option. if (Portal.begin()) { Serial.println("WiFi connected: " + WiFi.localIP().toString()); } }

void loop() { Portal.handleClient(); }` above are my code . I'm using iPhone. My doubt was during I uploading the coding the hone page timer remain as 1970 year and the clock remain as 0h 0 second . Its that able to change it as a real time clock or UTC clock ?

Hieromon commented 5 years ago

Simple.ino as an example has two assumptions. One is that the ESP module was able to connect to the Internet, and the other is to display the time by reloading the web page manually. It's not a real-time clock sketch application.

Hieromon commented 5 years ago

This topic is not relevant to the improvement of the AutoConnect library but is maintained to clarify the Simple.ino example's intent.