forked from airgradienthq/arduino
Redirect root path to dashboard
This commit is contained in:
@ -9,6 +9,7 @@ LocalServer::LocalServer(Stream &log, OpenMetrics &openMetrics,
|
|||||||
LocalServer::~LocalServer() {}
|
LocalServer::~LocalServer() {}
|
||||||
|
|
||||||
bool LocalServer::begin(void) {
|
bool LocalServer::begin(void) {
|
||||||
|
server.on("/", HTTP_GET, [this]() { _GET_root(); });
|
||||||
server.on("/measures/current", HTTP_GET, [this]() { _GET_measure(); });
|
server.on("/measures/current", HTTP_GET, [this]() { _GET_measure(); });
|
||||||
server.on(openMetrics.getApi(), HTTP_GET, [this]() { _GET_metrics(); });
|
server.on(openMetrics.getApi(), HTTP_GET, [this]() { _GET_metrics(); });
|
||||||
server.on("/config", HTTP_GET, [this]() { _GET_config(); });
|
server.on("/config", HTTP_GET, [this]() { _GET_config(); });
|
||||||
@ -43,6 +44,13 @@ String LocalServer::getHostname(void) {
|
|||||||
|
|
||||||
void LocalServer::_handle(void) { server.handleClient(); }
|
void LocalServer::_handle(void) { server.handleClient(); }
|
||||||
|
|
||||||
|
void LocalServer::_GET_root(void) {
|
||||||
|
String body = "If you are not redirected automatically, go to <a "
|
||||||
|
"href='http://192.168.4.1/dashboard'>dashboard</a>.";
|
||||||
|
|
||||||
|
server.send(302, "text/html", htmlResponse(body, true));
|
||||||
|
}
|
||||||
|
|
||||||
void LocalServer::_GET_config(void) {
|
void LocalServer::_GET_config(void) {
|
||||||
if(ag->isOne()) {
|
if(ag->isOne()) {
|
||||||
server.send(200, "application/json", config.toString());
|
server.send(200, "application/json", config.toString());
|
||||||
@ -204,5 +212,26 @@ String LocalServer::htmlDashboard(String timestamp) {
|
|||||||
page += "</script>";
|
page += "</script>";
|
||||||
page += "</html>";
|
page += "</html>";
|
||||||
|
|
||||||
|
return page;
|
||||||
|
}
|
||||||
|
|
||||||
|
String LocalServer::htmlResponse(String body, bool redirect) {
|
||||||
|
String page = "";
|
||||||
|
page += "<!DOCTYPE HTML>";
|
||||||
|
page += "<html lang=\"en-US\">";
|
||||||
|
page += " <head>";
|
||||||
|
page += " <meta charset=\"UTF-8\">";
|
||||||
|
|
||||||
|
if (redirect) {
|
||||||
|
page += " <meta http-equiv=\"refresh\" content=\"0;url=/dashboard\">";
|
||||||
|
}
|
||||||
|
|
||||||
|
page += " <title>Page Redirection</title>";
|
||||||
|
page += " </head>";
|
||||||
|
page += " <body>";
|
||||||
|
page += body;
|
||||||
|
page += " </body>";
|
||||||
|
page += "</html>";
|
||||||
|
|
||||||
return page;
|
return page;
|
||||||
}
|
}
|
@ -20,6 +20,7 @@ private:
|
|||||||
AgFirmwareMode fwMode;
|
AgFirmwareMode fwMode;
|
||||||
|
|
||||||
String htmlDashboard(String timestamp);
|
String htmlDashboard(String timestamp);
|
||||||
|
String htmlResponse(String body, bool redirect);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
LocalServer(Stream &log, OpenMetrics &openMetrics, Measurements &measure,
|
LocalServer(Stream &log, OpenMetrics &openMetrics, Measurements &measure,
|
||||||
@ -31,6 +32,7 @@ public:
|
|||||||
String getHostname(void);
|
String getHostname(void);
|
||||||
void setFwMode(AgFirmwareMode fwMode);
|
void setFwMode(AgFirmwareMode fwMode);
|
||||||
void _handle(void);
|
void _handle(void);
|
||||||
|
void _GET_root(void);
|
||||||
void _GET_config(void);
|
void _GET_config(void);
|
||||||
void _PUT_config(void);
|
void _PUT_config(void);
|
||||||
void _GET_metrics(void);
|
void _GET_metrics(void);
|
||||||
|
Reference in New Issue
Block a user