mirror of
https://github.com/usatiuk/EggbotWireless.git
synced 2025-10-26 16:57:48 +01:00
serve the webapp from esp8266
This commit is contained in:
BIN
Firmware/EggbotWireless/data/index.html.gz
Normal file
BIN
Firmware/EggbotWireless/data/index.html.gz
Normal file
Binary file not shown.
BIN
Firmware/EggbotWireless/data/src.02b6c58e.css.gz
Normal file
BIN
Firmware/EggbotWireless/data/src.02b6c58e.css.gz
Normal file
Binary file not shown.
BIN
Firmware/EggbotWireless/data/src.0511037d.js.gz
Normal file
BIN
Firmware/EggbotWireless/data/src.0511037d.js.gz
Normal file
Binary file not shown.
@@ -4,6 +4,7 @@
|
|||||||
#include <Arduino.h>
|
#include <Arduino.h>
|
||||||
#include <ESP8266WebServer.h>
|
#include <ESP8266WebServer.h>
|
||||||
#include <ArduinoJson.h>
|
#include <ArduinoJson.h>
|
||||||
|
#include <FS.h>
|
||||||
|
|
||||||
class WebAPI {
|
class WebAPI {
|
||||||
private:
|
private:
|
||||||
@@ -11,6 +12,8 @@ class WebAPI {
|
|||||||
void handlePutCommand();
|
void handlePutCommand();
|
||||||
void handleGetStatus();
|
void handleGetStatus();
|
||||||
void sendCORS();
|
void sendCORS();
|
||||||
|
bool getFile(String filename);
|
||||||
|
String getContentType(String filename);
|
||||||
|
|
||||||
String getStatusJson();
|
String getStatusJson();
|
||||||
public:
|
public:
|
||||||
|
|||||||
@@ -24,6 +24,49 @@ String WebAPI::getStatusJson() {
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String WebAPI::getContentType(String filename) {
|
||||||
|
if (server.hasArg("download")) {
|
||||||
|
return "application/octet-stream";
|
||||||
|
} else if (filename.endsWith(".html")) {
|
||||||
|
return "text/html";
|
||||||
|
} else if (filename.endsWith(".css")) {
|
||||||
|
return "text/css";
|
||||||
|
} else if (filename.endsWith(".js")) {
|
||||||
|
return "application/javascript";
|
||||||
|
} else if (filename.endsWith(".png")) {
|
||||||
|
return "image/png";
|
||||||
|
} else if (filename.endsWith(".gif")) {
|
||||||
|
return "image/gif";
|
||||||
|
} else if (filename.endsWith(".jpg")) {
|
||||||
|
return "image/jpeg";
|
||||||
|
} else if (filename.endsWith(".ico")) {
|
||||||
|
return "image/x-icon";
|
||||||
|
} else if (filename.endsWith(".xml")) {
|
||||||
|
return "text/xml";
|
||||||
|
} else if (filename.endsWith(".gz")) {
|
||||||
|
return "application/x-gzip";
|
||||||
|
}
|
||||||
|
return "text/plain";
|
||||||
|
}
|
||||||
|
|
||||||
|
bool WebAPI::getFile(String filename) {
|
||||||
|
if (filename.endsWith("/")) {
|
||||||
|
filename += "index.html";
|
||||||
|
}
|
||||||
|
String contentType = getContentType(filename);
|
||||||
|
String pathWithGz = filename + ".gz";
|
||||||
|
if (SPIFFS.exists(pathWithGz) || SPIFFS.exists(filename)) {
|
||||||
|
if (SPIFFS.exists(pathWithGz)) {
|
||||||
|
filename += ".gz";
|
||||||
|
}
|
||||||
|
File file = SPIFFS.open(filename, "r");
|
||||||
|
server.streamFile(file, contentType);
|
||||||
|
file.close();
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
void WebAPI::sendCORS() {
|
void WebAPI::sendCORS() {
|
||||||
server.sendHeader("Access-Control-Allow-Origin", "*");
|
server.sendHeader("Access-Control-Allow-Origin", "*");
|
||||||
server.sendHeader("Access-Control-Max-Age", "10000");
|
server.sendHeader("Access-Control-Max-Age", "10000");
|
||||||
@@ -38,8 +81,10 @@ void WebAPI::handleNotFound() {
|
|||||||
sendCORS();
|
sendCORS();
|
||||||
server.send(204);
|
server.send(204);
|
||||||
} else {
|
} else {
|
||||||
|
if (!getFile(server.uri())) {
|
||||||
server.send(404, "text/plain", "");
|
server.send(404, "text/plain", "");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void WebAPI::handlePutCommand() {
|
void WebAPI::handlePutCommand() {
|
||||||
@@ -61,6 +106,8 @@ void WebAPI::init() {
|
|||||||
std::bind(&WebAPI::handleGetStatus, this));
|
std::bind(&WebAPI::handleGetStatus, this));
|
||||||
|
|
||||||
server.onNotFound(std::bind(&WebAPI::handleNotFound, this));
|
server.onNotFound(std::bind(&WebAPI::handleNotFound, this));
|
||||||
|
|
||||||
|
SPIFFS.begin();
|
||||||
server.begin();
|
server.begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user