WLED/wled00/wled18_server.ino

394 lines
12 KiB
Arduino
Raw Normal View History

/*
* Server page definitions
*/
void initServer()
{
2019-02-14 17:25:41 +01:00
//CORS compatiblity
DefaultHeaders::Instance().addHeader("Access-Control-Allow-Origin", "*");
//settings page
2019-02-14 17:25:41 +01:00
server->on("/settings", HTTP_GET, [](AsyncWebServerRequest *request){
serveSettings(0);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/wifi", HTTP_GET, [](AsyncWebServerRequest *request){
if (!(wifiLock && otaLock))
{
serveSettings(1);
}else{
serveMessage(500, "Access Denied", txd, 254);
}
});
2019-02-14 17:25:41 +01:00
server->on("/settings/leds", HTTP_GET, [](AsyncWebServerRequest *request){
serveSettings(2);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/ui", HTTP_GET, [](AsyncWebServerRequest *request){
serveSettings(3);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/sync", HTTP_GET, [](AsyncWebServerRequest *request){
serveSettings(4);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/time", HTTP_GET, [](AsyncWebServerRequest *request){
serveSettings(5);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/sec", HTTP_GET, [](AsyncWebServerRequest *request){
serveSettings(6);
});
2019-02-14 17:25:41 +01:00
server->on("/favicon.ico", HTTP_GET, [](AsyncWebServerRequest *request){
if(!handleFileRead("/favicon.ico"))
{
2019-02-14 17:25:41 +01:00
server->send_P(200, "image/x-icon", favicon, 156);
}
});
2019-02-14 17:25:41 +01:00
server->on("/sliders", HTTP_GET, serveIndex);
2019-02-14 17:25:41 +01:00
server->on("/welcome", HTTP_GET, [](AsyncWebServerRequest *request){
serveSettings(255);
});
2019-02-14 17:25:41 +01:00
server->on("/reset", HTTP_GET, [](AsyncWebServerRequest *request){
serveMessage(200,"Rebooting now...","(takes ~20 seconds, wait for auto-redirect)",79);
reset();
});
2019-02-14 17:25:41 +01:00
server->on("/settings/wifi", HTTP_POST, [](AsyncWebServerRequest *request){
if (!(wifiLock && otaLock)) handleSettingsSet(1);
serveMessage(200,"WiFi settings saved.","Rebooting now...",255);
reset();
});
2019-02-14 17:25:41 +01:00
server->on("/settings/leds", HTTP_POST, [](AsyncWebServerRequest *request){
handleSettingsSet(2);
serveMessage(200,"LED settings saved.","Redirecting...",1);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/ui", HTTP_POST, [](AsyncWebServerRequest *request){
handleSettingsSet(3);
serveMessage(200,"UI settings saved.","Reloading to apply theme...",122);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/sync", HTTP_POST, [](AsyncWebServerRequest *request){
handleSettingsSet(4);
if (hueAttempt)
{
serveMessage(200,"Hue setup result",hueError,253);
} else {
serveMessage(200,"Sync settings saved.","Redirecting...",1);
}
hueAttempt = false;
});
2019-02-14 17:25:41 +01:00
server->on("/settings/time", HTTP_POST, [](AsyncWebServerRequest *request){
handleSettingsSet(5);
serveMessage(200,"Time settings saved.","Redirecting...",1);
});
2019-02-14 17:25:41 +01:00
server->on("/settings/sec", HTTP_POST, [](AsyncWebServerRequest *request){
handleSettingsSet(6);
serveMessage(200,"Security settings saved.","Rebooting now... (takes ~20 seconds, wait for auto-redirect)",139);
reset();
});
2019-02-10 23:05:06 +01:00
2019-02-14 17:25:41 +01:00
server->on("/json", HTTP_ANY, [](AsyncWebServerRequest *request){
server->send(500, "application/json", "{\"error\":\"Not implemented\"}");
2019-02-10 23:05:06 +01:00
});
2019-02-14 17:25:41 +01:00
server->on("/json/effects", HTTP_GET, [](AsyncWebServerRequest *request){
server->setContentLength(strlen_P(JSON_mode_names));
server->send(200, "application/json", "");
server->sendContent_P(JSON_mode_names);
2019-02-10 23:05:06 +01:00
});
2019-02-14 17:25:41 +01:00
server->on("/json/palettes", HTTP_GET, [](AsyncWebServerRequest *request){
server->setContentLength(strlen_P(JSON_palette_names));
server->send(200, "application/json", "");
server->sendContent_P(JSON_palette_names);
2019-02-10 23:05:06 +01:00
});
2019-02-14 17:25:41 +01:00
server->on("/version", HTTP_GET, [](AsyncWebServerRequest *request){
request->send(200, "text/plain", (String)VERSION);
});
2019-02-14 17:25:41 +01:00
server->on("/uptime", HTTP_GET, [](AsyncWebServerRequest *request){
request->send(200, "text/plain", (String)millis());
});
2019-02-14 17:25:41 +01:00
server->on("/freeheap", HTTP_GET, [](AsyncWebServerRequest *request){
request->send(200, "text/plain", (String)ESP.getFreeHeap());
});
2019-02-14 17:25:41 +01:00
server->on("/power", HTTP_GET, [](AsyncWebServerRequest *request){
String val = "";
if (strip.currentMilliamps == 0)
{
val = "Power calculation disabled";
} else
{
val += (String)strip.currentMilliamps;
val += "mA currently";
}
serveMessage(200, val, "This is just an estimate (does not account for factors like wire resistance). It is NOT a measurement!", 254);
});
2019-02-14 17:25:41 +01:00
server->on("/u", HTTP_GET, [](AsyncWebServerRequest *request){
server->setContentLength(strlen_P(PAGE_usermod));
server->send(200, "text/html", "");
server->sendContent_P(PAGE_usermod);
});
2019-02-14 17:25:41 +01:00
server->on("/teapot", HTTP_GET, [](AsyncWebServerRequest *request){
serveMessage(418, "418. I'm a teapot.", "(Tangible Embedded Advanced Project Of Twinkling)", 254);
});
2019-02-14 17:25:41 +01:00
server->on("/build", HTTP_GET, [](AsyncWebServerRequest *request){
getBuildInfo();
2019-02-14 17:25:41 +01:00
request->send(200, "text/plain", obuf);
});
//if OTA is allowed
if (!otaLock){
2019-02-14 17:25:41 +01:00
server->on("/edit", HTTP_GET, [](){
server->send(200, "text/html", PAGE_edit);
});
#ifdef USEFS
2019-02-14 17:25:41 +01:00
server->on("/edit", HTTP_PUT, handleFileCreate);
server->on("/edit", HTTP_DELETE, handleFileDelete);
server->on("/edit", HTTP_POST, [](){ server->send(200, "text/plain", ""); }, handleFileUpload);
server->on("/list", HTTP_GET, handleFileList);
#endif
//init ota page
#ifndef WLED_DISABLE_OTA
httpUpdater.setup(&server);
#else
2019-02-14 17:25:41 +01:00
server->on("/update", HTTP_GET, [](){
serveMessage(500, "Not implemented", "OTA updates are unsupported in this build.", 254);
});
#endif
} else
{
2019-02-14 17:25:41 +01:00
server->on("/edit", HTTP_GET, [](){
serveMessage(500, "Access Denied", txd, 254);
});
2019-02-14 17:25:41 +01:00
server->on("/update", HTTP_GET, [](){
serveMessage(500, "Access Denied", txd, 254);
});
2019-02-14 17:25:41 +01:00
server->on("/list", HTTP_GET, [](){
serveMessage(500, "Access Denied", txd, 254);
});
}
//this ceased working somehow
2019-02-14 17:25:41 +01:00
/*server->on("/", HTTP_GET, [](){
serveIndexOrWelcome();
});*/
//called when the url is not defined here, ajax-in; get-settings
2019-02-14 17:25:41 +01:00
server->onNotFound([](){
DEBUG_PRINTLN("Not-Found HTTP call:");
2019-02-14 17:25:41 +01:00
DEBUG_PRINTLN("URI: " + server->uri());
DEBUG_PRINTLN("Body: " + server->arg(0));
//make API CORS compatible
2019-02-14 17:25:41 +01:00
if (server->method() == HTTP_OPTIONS)
{
2019-02-14 17:25:41 +01:00
server->sendHeader("Access-Control-Allow-Origin", "*");
server->sendHeader("Access-Control-Max-Age", "10000");
server->sendHeader("Access-Control-Allow-Methods", "PUT,POST,GET,OPTIONS");
server->sendHeader("Access-Control-Allow-Headers", "*");
server->send(200);
return;
}
//workaround for subpage issue
2019-02-14 17:25:41 +01:00
if (server->uri().length() == 1)
{
serveIndexOrWelcome();
return;
}
2019-02-14 17:25:41 +01:00
if(!handleSet(server->uri())){
2019-01-09 22:52:42 +01:00
#ifndef WLED_DISABLE_ALEXA
2019-02-14 17:25:41 +01:00
if(!espalexa.handleAlexaApiCall(server->uri(),server->arg(0)))
2019-01-09 22:52:42 +01:00
#endif
2019-02-14 17:25:41 +01:00
server->send(404, "text/plain", "Not Found");
}
});
#ifndef ARDUINO_ARCH_ESP32
const char * headerkeys[] = {"User-Agent"};
2019-02-14 17:25:41 +01:00
server->collectHeaders(headerkeys,sizeof(headerkeys)/sizeof(char*));
#else
String ua = "User-Agent";
2019-02-14 17:25:41 +01:00
server->collectHeaders(ua);
#endif
}
void serveIndexOrWelcome()
{
if (!showWelcomePage){
serveIndex();
}else{
serveSettings(255);
}
}
void serveRealtimeError(bool settings)
{
String mesg = "The ";
mesg += (settings)?"settings":"WLED";
mesg += " UI is not available while receiving real-time data (";
if (realtimeIP[0] == 0)
{
mesg += "E1.31";
} else {
mesg += "UDP from ";
mesg += realtimeIP[0];
for (int i = 1; i < 4; i++)
{
mesg += ".";
mesg += realtimeIP[i];
}
}
mesg += ").";
2019-02-14 17:25:41 +01:00
server->send(200, "text/plain", mesg);
}
void getCSSColors()
{
char cs[6][9];
getThemeColors(cs);
oappend("<style>:root{--aCol:#"); oappend(cs[0]);
oappend(";--bCol:#"); oappend(cs[1]);
oappend(";--cCol:#"); oappend(cs[2]);
oappend(";--dCol:#"); oappend(cs[3]);
oappend(";--sCol:#"); oappend(cs[4]);
oappend(";--tCol:#"); oappend(cs[5]);
oappend(";--cFn:"); oappend(cssFont);
oappend(";}");
}
void serveIndex()
{
bool serveMobile = false;
2019-02-14 17:25:41 +01:00
if (uiConfiguration == 0) serveMobile = checkClientIsMobile(server->header("User-Agent"));
else if (uiConfiguration == 2) serveMobile = true;
if (realtimeActive && !enableRealtimeUI) //do not serve while receiving realtime
{
serveRealtimeError(false);
return;
}
//error message is not gzipped
#ifdef WLED_DISABLE_MOBILE_UI
2019-02-14 17:25:41 +01:00
if (!serveMobile) server->sendHeader("Content-Encoding","gzip");
#else
2019-02-14 17:25:41 +01:00
server->sendHeader("Content-Encoding","gzip");
#endif
2019-02-14 17:25:41 +01:00
server->send_P(200, "text/html",
(serveMobile) ? PAGE_indexM : PAGE_index0,
(serveMobile) ? PAGE_indexM_L : PAGE_index0_L);
}
void serveMessage(int code, String headl, String subl="", int optionType)
{
olen = 0;
getCSSColors();
String messageBody = "<h2>";
messageBody += headl;
messageBody += "</h2>";
messageBody += subl;
switch(optionType)
{
case 255: break; //simple message
case 254: messageBody += "<br><br><button type=\"button\" onclick=\"B()\">Back</button>"; break; //back button
case 253: messageBody += "<br><br><form action=/settings><button type=submit>Back</button></form>"; //button to settings
}
if (optionType < 60) //redirect to settings after optionType seconds
{
messageBody += "<script>setTimeout(RS," + String(optionType*1000) + ")</script>";
} else if (optionType < 120) //redirect back after optionType-60 seconds
{
messageBody += "<script>setTimeout(B," + String((optionType-60)*1000) + ")</script>";
} else if (optionType < 180) //reload parent after optionType-120 seconds
{
messageBody += "<script>setTimeout(RP," + String((optionType-120)*1000) + ")</script>";
}
messageBody += "</body></html>";
2019-02-14 17:25:41 +01:00
server->setContentLength(strlen_P(PAGE_msg0) + olen + strlen_P(PAGE_msg1) + messageBody.length());
server->send(code, "text/html", "");
server->sendContent_P(PAGE_msg0);
server->sendContent(obuf);
server->sendContent_P(PAGE_msg1);
server->sendContent(messageBody);
}
void serveSettings(byte subPage)
{
if (realtimeActive && !enableRealtimeUI) //do not serve while receiving realtime
{
serveRealtimeError(true);
return;
}
#ifdef WLED_DISABLE_MOBILE_UI //disable welcome page if not enough storage
if (subPage == 255) {serveIndex(); return;}
#endif
int pl0, pl1;
switch (subPage) //0: menu 1: wifi 2: leds 3: ui 4: sync 5: time 6: sec 255: welcomepage
{
case 1: pl0 = strlen_P(PAGE_settings_wifi0); pl1 = strlen_P(PAGE_settings_wifi1); break;
case 2: pl0 = strlen_P(PAGE_settings_leds0); pl1 = strlen_P(PAGE_settings_leds1); break;
case 3: pl0 = strlen_P(PAGE_settings_ui0); pl1 = strlen_P(PAGE_settings_ui1); break;
case 4: pl0 = strlen_P(PAGE_settings_sync0); pl1 = strlen_P(PAGE_settings_sync1); break;
case 5: pl0 = strlen_P(PAGE_settings_time0); pl1 = strlen_P(PAGE_settings_time1); break;
case 6: pl0 = strlen_P(PAGE_settings_sec0); pl1 = strlen_P(PAGE_settings_sec1); break;
case 255: pl0 = strlen_P(PAGE_welcome0); pl1 = strlen_P(PAGE_welcome1); break;
default: pl0 = strlen_P(PAGE_settings0); pl1 = strlen_P(PAGE_settings1);
}
uint16_t sCssLength = (subPage >0 && subPage <7)?strlen_P(PAGE_settingsCss):0;
getSettingsJS(subPage);
getCSSColors();
2019-02-14 17:25:41 +01:00
server->setContentLength(pl0 + olen + sCssLength + pl1);
server->send(200, "text/html", "");
switch (subPage)
{
2019-02-14 17:25:41 +01:00
case 1: server->sendContent_P(PAGE_settings_wifi0); break;
case 2: server->sendContent_P(PAGE_settings_leds0); break;
case 3: server->sendContent_P(PAGE_settings_ui0 ); break;
case 4: server->sendContent_P(PAGE_settings_sync0); break;
case 5: server->sendContent_P(PAGE_settings_time0); break;
case 6: server->sendContent_P(PAGE_settings_sec0 ); break;
case 255: server->sendContent_P(PAGE_welcome0 ); break;
default: server->sendContent_P(PAGE_settings0 );
}
2019-02-14 17:25:41 +01:00
server->sendContent(obuf);
2019-02-14 17:25:41 +01:00
if (subPage >0 && subPage <7) server->sendContent_P(PAGE_settingsCss);
switch (subPage)
{
2019-02-14 17:25:41 +01:00
case 1: server->sendContent_P(PAGE_settings_wifi1); break;
case 2: server->sendContent_P(PAGE_settings_leds1); break;
case 3: server->sendContent_P(PAGE_settings_ui1 ); break;
case 4: server->sendContent_P(PAGE_settings_sync1); break;
case 5: server->sendContent_P(PAGE_settings_time1); break;
case 6: server->sendContent_P(PAGE_settings_sec1 ); break;
case 255: server->sendContent_P(PAGE_welcome1 ); break;
default: server->sendContent_P(PAGE_settings1 );
}
}