Skip to content

Commit 317a152

Browse files
committed
Add HTTPS
1 parent 490eb0f commit 317a152

File tree

2 files changed

+66
-27
lines changed

2 files changed

+66
-27
lines changed

examples/arduino/w5500-http/mongoose_config.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -14,5 +14,5 @@
1414
#define MG_ENABLE_TCPIP_PRINT_DEBUG_STATS 0
1515
#define MG_ENABLE_CUSTOM_MILLIS 1
1616
#define MG_ENABLE_CUSTOM_RANDOM 1
17-
// #define MG_TLS MG_TLS_BUILTIN
18-
#define MG_IO_SIZE 128
17+
#define MG_TLS MG_TLS_BUILTIN
18+
#define MG_IO_SIZE 256

examples/arduino/w5500-http/w5500-http.ino

Lines changed: 64 additions & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,8 @@
11
#include <SPI.h>
22
#include "mongoose.h"
33

4-
#define LED_PIN LED_BUILTIN // LED pin - can be LED_BUILTIN
5-
#define SS_PIN 17 // Slave select pin
4+
#define LED_PIN LED_BUILTIN // LED pin
5+
#define SS_PIN 17 // Slave select pin for the W5500 module
66

77
struct mg_tcpip_spi spi = {
88
NULL, // SPI metadata
@@ -13,22 +13,76 @@ struct mg_tcpip_spi spi = {
1313
struct mg_mgr mgr; // Mongoose event manager
1414
struct mg_tcpip_if mif = {.mac = {2, 0, 1, 2, 3, 5}}; // Network interface
1515

16+
// Used by Mongoose for time tracking
1617
uint64_t mg_millis(void) {
1718
return millis();
1819
}
1920

21+
// Used by Mongoose to generate random data
2022
bool mg_random(void *buf, size_t len) { // For TLS
2123
uint8_t *p = (uint8_t *) buf;
2224
while (len--) *p++ = (unsigned char) (rand() & 255);
2325
return true;
2426
}
2527

2628
// Crude function to get available RAM, for quick profiling
27-
size_t getFreeRAM(void) {
28-
size_t size = 0, increment = 100;
29-
void *p;
30-
while ((p = malloc(size)) != NULL) free(p), size += increment;
31-
return size;
29+
extern "C" char *sbrk(int);
30+
extern char *__brkval;
31+
int getFreeRAM() {
32+
char top;
33+
#ifdef __arm__
34+
return &top - (char *) sbrk(0);
35+
#elif defined(CORE_TEENSY) || (ARDUINO > 103 && ARDUINO != 151)
36+
return &top - __brkval;
37+
#else
38+
return __brkval ? &top - __brkval : &top - __malloc_heap_start;
39+
#endif
40+
}
41+
42+
static void http_ev_handler(struct mg_connection *c, int ev, void *ev_data) {
43+
if (ev == MG_EV_HTTP_MSG) {
44+
struct mg_http_message *hm = (struct mg_http_message *) ev_data;
45+
if (mg_match(hm->uri, mg_str("/api/led/on"), NULL)) {
46+
digitalWrite(LED_PIN, HIGH);
47+
mg_http_reply(c, 200, "", "{%m: %d}\n", MG_ESC("led"), digitalRead(LED_PIN));
48+
} else if (mg_match(hm->uri, mg_str("/api/led/off"), NULL)) {
49+
digitalWrite(LED_PIN, LOW);
50+
mg_http_reply(c, 200, "", "{%m: %d}\n", MG_ESC("led"), digitalRead(LED_PIN));
51+
} else {
52+
mg_http_reply(c, 200, "", "ok, free RAM: %u\n", getFreeRAM());
53+
}
54+
}
55+
// Initialise TLS if we're a TLS listener
56+
if (ev == MG_EV_ACCEPT && c->fn_data != NULL) {
57+
struct mg_tls_opts opts;
58+
memset(&opts, 0, sizeof(opts));
59+
60+
// Generated by https://mongoose.ws/tls/
61+
#define TLS_CERT \
62+
"-----BEGIN CERTIFICATE-----\n" \
63+
"MIIBkzCCATqgAwIBAgIEZ3E9lzAKBggqhkjOPQQDAjATMREwDwYDVQQDEwhNb25n\n" \
64+
"b29zZTAeFw0yNDEyMjkxMjE2MjNaFw0zNDEyMjcxMjE2MjNaMBQxEjAQBgNVBAMT\n" \
65+
"CWxvY2FsaG9zdDBZMBMGByqGSM49AgEGCCqGSM49AwEHA0IABHxxuByu5K2k7DYq\n" \
66+
"b3eQsHb3VY5NWglWun7axh69OWF7V9OUUyON1y8ISirL0Gj5ZPOogIgrB9iOcz6K\n" \
67+
"q9n8NQOjezB5MA4GA1UdDwEB/wQEAwIFoDATBgNVHSUEDDAKBggrBgEFBQcDATAM\n" \
68+
"BgNVHRMBAf8EAjAAMB8GA1UdIwQYMBaAFGn8GpPWaM0JC7U4zlg+bCljSjLoMCMG\n" \
69+
"A1UdEQQcMBqCCWxvY2FsaG9zdIINMTkyLjE2OC4wLjEwMDAKBggqhkjOPQQDAgNH\n" \
70+
"ADBEAiAr1fO3QLLm+vjYarctNI+gfnxxB4edRTRmcFWHmBS8oQIgY5lkq2JCwATG\n" \
71+
"YsVQUmS+2Tbc7ij7lkduXO42pvr/0fw=\n" \
72+
"-----END CERTIFICATE-----"
73+
74+
#define TLS_KEY \
75+
"-----BEGIN EC PRIVATE KEY-----\n" \
76+
"MHcCAQEEIHKu84eEw9dX8nez82g3F94OsZJ14LVbAN+OBW+++V2poAoGCCqGSM49\n" \
77+
"AwEHoUQDQgAEfHG4HK7kraTsNipvd5CwdvdVjk1aCVa6ftrGHr05YXtX05RTI43X\n" \
78+
"LwhKKsvQaPlk86iAiCsH2I5zPoqr2fw1Aw==\n" \
79+
"-----END EC PRIVATE KEY-----"
80+
81+
opts.cert = mg_str(TLS_CERT);
82+
opts.key = mg_str(TLS_KEY);
83+
84+
mg_tls_init(c, &opts);
85+
}
3286
}
3387

3488
void setup() {
@@ -46,24 +100,9 @@ void setup() {
46100
mif.driver_data = &spi; // Pass SPI interface to W5500 driver
47101
mg_tcpip_init(&mgr, &mif); // Initialise built-in TCP/IP stack
48102

49-
// Setup HTTP listener. Respond "ok" on any HTTP request
50-
mg_http_listen(
51-
&mgr, "http://0.0.0.0",
52-
[](struct mg_connection *c, int ev, void *ev_data) {
53-
if (ev == MG_EV_HTTP_MSG) {
54-
struct mg_http_message *hm = (struct mg_http_message *) ev_data;
55-
if (mg_match(hm->uri, mg_str("/api/led/on"), NULL)) {
56-
digitalWrite(LED_PIN, HIGH);
57-
mg_http_reply(c, 200, "", "{%m: %d}\n", MG_ESC("led"), digitalRead(LED_PIN));
58-
} else if (mg_match(hm->uri, mg_str("/api/led/off"), NULL)) {
59-
digitalWrite(LED_PIN, LOW);
60-
mg_http_reply(c, 200, "", "{%m: %d}\n", MG_ESC("led"), digitalRead(LED_PIN));
61-
} else {
62-
mg_http_reply(c, 200, "", "ok, free RAM: %u\n", getFreeRAM());
63-
}
64-
}
65-
},
66-
&mgr);
103+
// Setup HTTP & HTTPS listeners. Respond "ok" on any HTTP request
104+
mg_http_listen(&mgr, "http://0.0.0.0:80", http_ev_handler, NULL);
105+
mg_http_listen(&mgr, "https://0.0.0.0:443", http_ev_handler, (void *) 1);
67106
}
68107

69108
void loop() {

0 commit comments

Comments
 (0)