Compare commits
5 Commits
4b13827803
...
18ed46d2db
Author | SHA1 | Date | |
---|---|---|---|
18ed46d2db | |||
281aab33b8 | |||
7f7959778c | |||
852932a934 | |||
71facb7d18 |
@ -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
34
src/socketserver.h
Normal 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};
|
||||||
|
};
|
25
src/util.h
25
src/util.h
@ -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();
|
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user