Compare commits

...

5 Commits

Author SHA1 Message Date
18ed46d2db Add HTTP API endpoint for raw messages
RESTful version of simple socket listener.
2024-04-12 03:22:24 +02:00
281aab33b8 [fixup] Extract hexDump function 2024-04-12 03:21:52 +02:00
7f7959778c Extract hexDump function 2024-04-12 03:21:41 +02:00
852932a934 Fix typo 2024-04-12 03:21:30 +02:00
71facb7d18 Add socket server compatible with original software 2024-04-11 14:38:45 +02:00
4 changed files with 70 additions and 11 deletions

View File

@ -4,9 +4,11 @@
#include "credentials.h" #include "credentials.h"
#include "webserver.h" #include "webserver.h"
#include "socketserver.h"
#include "util.h" #include "util.h"
static ESP8266WiFiMulti wifiMulti; static ESP8266WiFiMulti wifiMulti;
static SocketServer socketServer;
void setup() { void setup() {
// serial console, for use via USB (also exposed to TXD0/RXD0 GPIOs) // serial console, for use via USB (also exposed to TXD0/RXD0 GPIOs)
@ -43,10 +45,12 @@ void setup() {
// configure HTTP endpoints // configure HTTP endpoints
configureWebServer(); configureWebServer();
// don't forget to start the webserver! // don't forget to start all the services
webServer.begin(); webServer.begin();
socketServer.begin();
} }
void loop() { void loop() {
webServer.handleClient(); webServer.handleClient();
socketServer.handleClient();
} }

34
src/socketserver.h Normal file
View File

@ -0,0 +1,34 @@
#pragma once
class SocketServer {
public:
static constexpr int Port = 3000;
void begin() {
_server.begin();
}
void handleClient() {
auto client = _server.available();
if (client) {
Serial.println("Client connected to socket server: " + client.remoteIP().toString() + ":" + client.remotePort());
} else {
return;
}
while (client.connected()) {
while (client.available() > 0) {
auto chr = client.read();
Serial.write(chr);
Serial1.write(chr);
}
}
client.stop();
Serial.println();
Serial.println("Client disconnected");
}
private:
WiFiServer _server{Port};
};

View File

@ -122,7 +122,7 @@ enum class ExtendedChar {
LatinSmallLetterAWithCircumflex = 0x83, LatinSmallLetterAWithCircumflex = 0x83,
// ä // ä
LatinSmallLetterAWithDiaeresis = 0x84, LatinSmallLetterAWithDiaeresis = 0x84,
// á // à
LatinSmallLetterAWithGrave = 0x85, LatinSmallLetterAWithGrave = 0x85,
// å // å
LatinSmallLetterAWithRingAbove = 0x86, LatinSmallLetterAWithRingAbove = 0x86,
@ -246,6 +246,19 @@ enum class ExtendedChar {
GreekSmallLetterPhi = 0xed, GreekSmallLetterPhi = 0xed,
}; };
String hexDump(String in) {
String out;
for (size_t i = 0; i < in.length(); ++i) {
auto hexChar = String(in[i], HEX);
if (hexChar.length() == 1) {
out.concat('0');
}
out.concat(hexChar);
out.concat(' ');
}
return out;
}
/* /*
* Message syntax: * Message syntax:
* separator: ~ * separator: ~
@ -299,13 +312,5 @@ void sendTextToSign(
Serial1.print(toSend); Serial1.print(toSend);
Serial.println("Text sent to device: " + toSend); Serial.println("Text sent to device: " + toSend);
Serial.print("Hex dump: "); Serial.println("Hex dump: " + hexDump(toSend));
for (size_t i = 0; i < toSend.length(); ++i) {
auto hexChar = String(toSend[i], HEX);
if (hexChar.length() == 1) {
hexChar = '0' + hexChar;
}
Serial.print(hexChar + ' ');
}
Serial.println();
} }

View File

@ -66,6 +66,21 @@ namespace {
sendTextToSign(text); sendTextToSign(text);
webServer.send(200, "text/plain", "ok"); webServer.send(200, "text/plain", "ok");
} }
// RESTful API endpoint -- returns a proper status code rather than a redirect
void handleRawApiSend() {
String toSend = webServer.arg("plain");
if (toSend.isEmpty()) {
webServer.send(404, "text/plain", "empty body");
return;
}
Serial.println("Raw message sent to device: " + toSend);
Serial.println("Hex dump: " + hexDump(toSend));
Serial1.print(toSend);
webServer.send(200, "text/plain", "ok");
}
} }
void configureWebServer() { void configureWebServer() {
@ -74,4 +89,5 @@ void configureWebServer() {
webServer.on("/", HTTPMethod::HTTP_GET, handleIndex); webServer.on("/", HTTPMethod::HTTP_GET, handleIndex);
webServer.on("/", HTTPMethod::HTTP_POST, handleFormSend); webServer.on("/", HTTPMethod::HTTP_POST, handleFormSend);
webServer.on("/send", HTTPMethod::HTTP_POST, handleApiSend); webServer.on("/send", HTTPMethod::HTTP_POST, handleApiSend);
webServer.on("/raw", HTTPMethod::HTTP_POST, handleRawApiSend);
} }