mirror of
https://github.com/cesanta/mongoose.git
synced 2024-12-25 22:20:49 +08:00
Simplify MQTT example
This commit is contained in:
parent
85613ab02d
commit
3caca03e8a
@ -1,7 +1,7 @@
|
||||
#include <SPI.h>
|
||||
#include "mongoose.h"
|
||||
|
||||
#define SS_PIN 3 // Slave select pin
|
||||
#define SS_PIN 17 // Slave select pin
|
||||
struct mg_mgr mgr; // Mongoose event manager
|
||||
struct mg_tcpip_spi spi = {
|
||||
NULL, // SPI data
|
||||
@ -13,15 +13,18 @@ struct mg_tcpip_if mif = {.mac = {2, 0, 1, 2, 3, 5}}; // network interface
|
||||
|
||||
void setup() {
|
||||
Serial.begin(115200);
|
||||
mg_log_set_fn([](char ch, void *) { Serial.print(ch); }, NULL);
|
||||
mg_log_set(MG_LL_DEBUG);
|
||||
while (!Serial) (void) 0;
|
||||
|
||||
pinMode(SS_PIN, OUTPUT);
|
||||
SPI.begin();
|
||||
|
||||
// Set logging function to a serial print
|
||||
mg_log_set_fn([](char ch, void *) { Serial.print(ch); }, NULL);
|
||||
mg_mgr_init(&mgr);
|
||||
|
||||
delay(3000);
|
||||
// delay(3000);
|
||||
MG_INFO(("Starting TCP/IP stack..."));
|
||||
SPI.transfer(0);
|
||||
MG_INFO(("--->..."));
|
||||
|
||||
mif.driver = &mg_tcpip_driver_w5500;
|
||||
mif.driver_data = &spi;
|
||||
|
@ -13,5 +13,10 @@
|
||||
#define MG_ENABLE_DRIVER_W5500 1
|
||||
#define MG_ENABLE_TCPIP_DRIVER_INIT 0
|
||||
#define mkdir(a, b) (-1)
|
||||
#define MG_IO_SIZE 512
|
||||
//#define MG_ENABLE_LOG 0
|
||||
#define MG_ENABLE_TCPIP_PRINT_DEBUG_STATS 0
|
||||
#define MG_ENABLE_CUSTOM_MILLIS 1
|
||||
#define MG_IO_SIZE 128
|
||||
|
||||
// Enable TLS
|
||||
// #define MG_TLS MG_TLS_BUILTIN
|
||||
// #define MG_ENABLE_CUSTOM_RANDOM 1
|
||||
|
@ -1,58 +0,0 @@
|
||||
#include "net.h"
|
||||
|
||||
#define MQTT_SERVER "mqtt://broker.hivemq.com:1883"
|
||||
struct mg_connection *mqtt_connection;
|
||||
const char *mqtt_subscribe_topic = "mg/rx";
|
||||
const char *mqtt_publish_topic = "mg/tx";
|
||||
|
||||
struct mg_mgr mgr; // Mongoose event manager
|
||||
struct mg_tcpip_if mif = {.mac = {2, 0, 1, 2, 3, 5}}; // network interface
|
||||
|
||||
void mqtt_publish(const char *message) {
|
||||
struct mg_mqtt_opts opts = {};
|
||||
opts.topic = mg_str(mqtt_publish_topic);
|
||||
opts.message = mg_str(message);
|
||||
if (mqtt_connection) mg_mqtt_pub(mqtt_connection, &opts);
|
||||
}
|
||||
|
||||
static void fn(struct mg_connection *c, int ev, void *ev_data) {
|
||||
if (ev == MG_EV_MQTT_OPEN) {
|
||||
MG_INFO(("%lu CONNECTED to %s", c->id, MQTT_SERVER));
|
||||
struct mg_mqtt_opts opts = {};
|
||||
opts.topic = mg_str(mqtt_subscribe_topic);
|
||||
mg_mqtt_sub(c, &opts);
|
||||
MG_INFO(("%lu SUBSCRIBED to %s", c->id, mqtt_subscribe_topic));
|
||||
} else if (ev == MG_EV_MQTT_MSG) {
|
||||
// Received MQTT message
|
||||
struct mg_mqtt_message *mm = (struct mg_mqtt_message *) ev_data;
|
||||
MG_INFO(("%lu RECEIVED %.*s <- %.*s", c->id, (int) mm->data.len,
|
||||
mm->data.buf, (int) mm->topic.len, mm->topic.buf));
|
||||
exec_command(mm->data.buf, mm->data.len);
|
||||
} else if (ev == MG_EV_CLOSE) {
|
||||
MG_INFO(("%lu CLOSED", c->id));
|
||||
mqtt_connection = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
static void timer_fn(void *arg) {
|
||||
struct mg_mgr *mgr = (struct mg_mgr *) arg;
|
||||
struct mg_mqtt_opts opts;
|
||||
memset(&opts, 0, sizeof(opts));
|
||||
opts.clean = true;
|
||||
if (mif.state == MG_TCPIP_STATE_READY && mqtt_connection == NULL) {
|
||||
mqtt_connection = mg_mqtt_connect(mgr, MQTT_SERVER, &opts, fn, NULL);
|
||||
}
|
||||
// MG_INFO(("Eth: %d, MQTT: %p", mif.state, mqtt_connection));
|
||||
}
|
||||
|
||||
void net_init(void) {
|
||||
// Set Mongoose logging function to a serial print
|
||||
mg_mgr_init(&mgr);
|
||||
|
||||
mif.driver = &mg_tcpip_driver_w5500;
|
||||
mif.driver_data = &spi;
|
||||
mg_tcpip_init(&mgr, &mif);
|
||||
|
||||
// Start a timer that keeps MQTT connection alive
|
||||
mg_timer_add(&mgr, 3000, MG_TIMER_REPEAT, timer_fn, &mgr);
|
||||
}
|
@ -1,16 +0,0 @@
|
||||
#pragma once
|
||||
#include "mongoose.h"
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern struct mg_tcpip_spi spi;
|
||||
extern struct mg_mgr mgr;
|
||||
void mqtt_publish(const char *message);
|
||||
void net_init(void);
|
||||
void exec_command(const char *req, size_t req_len);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
@ -1,51 +1,88 @@
|
||||
#include <SPI.h>
|
||||
#include "net.h"
|
||||
#include "mongoose.h"
|
||||
|
||||
#define SS_PIN 17 // Slave select pin
|
||||
#define MQTT_SERVER "mqtt://broker.hivemq.com:1883"
|
||||
#define MQTT_SUB_TOPIC "mg/rx" // Subscribe to this topic
|
||||
#define MQTT_PUB_TOPIC "mg/tx" // Publish to this topic
|
||||
#define SS_PIN 2 // Slave select pin
|
||||
#define LED_PIN 21 // LED pin
|
||||
|
||||
struct mg_connection *mqtt_connection;
|
||||
struct mg_tcpip_spi spi = {
|
||||
NULL, // SPI data
|
||||
[](void *) { digitalWrite(SS_PIN, LOW); }, // Begin transaction
|
||||
[](void *) { digitalWrite(SS_PIN, HIGH); }, // End transaction
|
||||
[](void *, uint8_t c) { return SPI.transfer(c); }, // Execute transaction
|
||||
NULL, // SPI metadata
|
||||
[](void *) { digitalWrite(SS_PIN, LOW); SPI.beginTransaction(SPISettings()); },
|
||||
[](void *) { digitalWrite(SS_PIN, HIGH); SPI.endTransaction(); },
|
||||
[](void *, uint8_t c) { return SPI.transfer(c); }, // Execute transaction
|
||||
};
|
||||
struct mg_mgr mgr; // Mongoose event manager
|
||||
struct mg_tcpip_if mif = {.mac = {2, 0, 1, 2, 3, 5}}; // Network interface
|
||||
|
||||
void exec_command(const char *req, size_t req_len) {
|
||||
char res[100];
|
||||
if (req_len == 2 && strncmp(req, "on", req_len) == 0) {
|
||||
digitalWrite(LED_BUILTIN, true);
|
||||
snprintf(res, sizeof(res), "LED on");
|
||||
} else if (req_len == 3 && strncmp(req, "off", req_len) == 0) {
|
||||
digitalWrite(LED_BUILTIN, false);
|
||||
snprintf(res, sizeof(res), "LED off");
|
||||
} else {
|
||||
snprintf(res, sizeof(res), "Unknown command: [%.*s]", (int) req_len, req);
|
||||
}
|
||||
Serial.println(res);
|
||||
mqtt_publish(res);
|
||||
uint64_t mg_millis(void) {
|
||||
return millis();
|
||||
}
|
||||
|
||||
static void process_input(char c) {
|
||||
static char buf[100];
|
||||
static size_t len = 0;
|
||||
char response[100];
|
||||
if (c != '\n' && c != '\0') buf[len++] = c; // Append to the buffer
|
||||
if (len >= sizeof(buf)) len = 0; // On overflow, reset
|
||||
if (c == '\n' && len > 0) {
|
||||
exec_command(buf, len);
|
||||
len = 0;
|
||||
void mqtt_publish(const char *message) {
|
||||
struct mg_mqtt_opts opts = {};
|
||||
opts.topic = mg_str(MQTT_PUB_TOPIC);
|
||||
opts.message = mg_str(message);
|
||||
if (mqtt_connection) mg_mqtt_pub(mqtt_connection, &opts);
|
||||
}
|
||||
|
||||
void handle_command(struct mg_str msg) {
|
||||
if (msg.len == 3 && memcmp(msg.buf, "off", 3) == 0) {
|
||||
digitalWrite(LED_PIN, LOW);
|
||||
mqtt_publish("done - off");
|
||||
} else if (msg.len == 2 && memcmp(msg.buf, "on", 2) == 0) {
|
||||
digitalWrite(LED_PIN, HIGH);
|
||||
mqtt_publish("done - on");
|
||||
}
|
||||
}
|
||||
|
||||
static void mqtt_ev_handler(struct mg_connection *c, int ev, void *ev_data) {
|
||||
if (ev == MG_EV_MQTT_OPEN) {
|
||||
MG_INFO(("%lu CONNECTED to %s", c->id, MQTT_SERVER));
|
||||
struct mg_mqtt_opts opts = {};
|
||||
opts.topic = mg_str(MQTT_SUB_TOPIC);
|
||||
mg_mqtt_sub(c, &opts);
|
||||
MG_INFO(("%lu SUBSCRIBED to %s", c->id, MQTT_SUB_TOPIC));
|
||||
} else if (ev == MG_EV_MQTT_MSG) {
|
||||
// Received MQTT message
|
||||
struct mg_mqtt_message *mm = (struct mg_mqtt_message *) ev_data;
|
||||
MG_INFO(("%lu RECEIVED %.*s <- %.*s", c->id, (int) mm->data.len,
|
||||
mm->data.buf, (int) mm->topic.len, mm->topic.buf));
|
||||
handle_command(mm->data);
|
||||
} else if (ev == MG_EV_CLOSE) {
|
||||
MG_INFO(("%lu CLOSED", c->id));
|
||||
mqtt_connection = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
void reconnect_if_not_connected(void) {
|
||||
if (mif.state == MG_TCPIP_STATE_READY && mqtt_connection == NULL) {
|
||||
struct mg_mqtt_opts opts = {};
|
||||
opts.clean = true;
|
||||
mqtt_connection =
|
||||
mg_mqtt_connect(&mgr, MQTT_SERVER, &opts, mqtt_ev_handler, NULL);
|
||||
}
|
||||
}
|
||||
|
||||
void setup() {
|
||||
Serial.begin(115200);
|
||||
SPI.begin();
|
||||
pinMode(SS_PIN, OUTPUT);
|
||||
pinMode(LED_BUILTIN, OUTPUT);
|
||||
mg_log_set_fn([](char ch, void *) { Serial.print(ch); }, NULL);
|
||||
net_init();
|
||||
Serial.begin(115200); // Initialise serial
|
||||
while (!Serial) delay(50); // for debug output
|
||||
|
||||
SPI.begin(); // Iniitialise SPI
|
||||
pinMode(SS_PIN, OUTPUT); // to communicate with W5500 Ethernet module
|
||||
pinMode(LED_PIN, OUTPUT); // Initialise LED
|
||||
|
||||
mg_mgr_init(&mgr); // Initialise Mongoose event manager
|
||||
mg_log_set(MG_LL_DEBUG); // Set debug log level
|
||||
mg_log_set_fn([](char ch, void *) { Serial.print(ch); }, NULL); // Log serial
|
||||
mif.driver = &mg_tcpip_driver_w5500; // Use W5500 built-in driver
|
||||
mif.driver_data = &spi; // Pass SPI interface to W5500 driver
|
||||
mg_tcpip_init(&mgr, &mif); // Initialise built-in TCP/IP stack
|
||||
}
|
||||
|
||||
void loop() {
|
||||
if (Serial.available()) process_input(Serial.read());
|
||||
mg_mgr_poll(&mgr, 1);
|
||||
mg_mgr_poll(&mgr, 1); // Process network events
|
||||
reconnect_if_not_connected(); // Reconnect to MQTT server if needed
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user