1
0
mirror of https://github.com/daniviga/bite.git synced 2025-04-20 14:31:20 +02:00

Add MQTT support on Arduino

This commit is contained in:
Daniele Viganò 2020-06-08 09:51:46 +02:00
parent bbb92100f8
commit 55e58680ac
Signed by: dani
GPG Key ID: DB49AFC03C40EE02
3 changed files with 57 additions and 11 deletions

View File

@ -1,12 +1,16 @@
#include <EEPROM.h> #include <EEPROM.h>
#include <Ethernet.h> #include <Ethernet.h>
#include <EthernetUdp.h> #include <EthernetUdp.h>
#include <PubSubClient.h>
#include <NTPClient.h> #include <NTPClient.h>
#include <ArduinoJson.h> #include <ArduinoJson.h>
#define DEBUG_TO_SERIAL 1 #define DEBUG_TO_SERIAL 1 // debug on serial port
#define USE_MQTT 0 // use mqtt protocol instead of http post
#define USE_INTERNAL_NTP 0 // use default ntp server or the internal one #define USE_INTERNAL_NTP 0 // use default ntp server or the internal one
#define AREF_VOLTAGE 3.3 #define AREF_VOLTAGE 3.3 // set aref voltage to 3.3v instead of default 5v
char serial[9];
// const String serverName = "sensor.server.domain"; // const String serverName = "sensor.server.domain";
const size_t capacity = 2 * JSON_OBJECT_SIZE(3) + JSON_OBJECT_SIZE(2) + 20; const size_t capacity = 2 * JSON_OBJECT_SIZE(3) + JSON_OBJECT_SIZE(2) + 20;
@ -17,11 +21,13 @@ JsonObject temp = payload.createNestedObject("temperature");
unsigned int counter = 0; unsigned int counter = 0;
EthernetUDP ntpUDP; EthernetUDP ntpUDP;
NTPClient timeClient(ntpUDP); NTPClient timeClient(ntpUDP);
bool NTPValid = false; bool NTPValid = false;
EthernetClient ethClient;
PubSubClient clientMQTT(ethClient);
struct netConfig { struct netConfig {
IPAddress address; IPAddress address;
unsigned int port; unsigned int port;
@ -39,8 +45,6 @@ void setup(void) {
StaticJsonDocument<20> api; StaticJsonDocument<20> api;
byte mac[6]; byte mac[6];
char serial[9];
int eeAddress = 0; int eeAddress = 0;
EEPROM.get(eeAddress, mac); EEPROM.get(eeAddress, mac);
@ -60,10 +64,10 @@ void setup(void) {
Serial.print("IoT #"); Serial.print("IoT #");
Serial.print(serial); Serial.print(serial);
Serial.println(" at address:"); Serial.print(" at address: ");
Serial.println(Ethernet.localIP()); Serial.println(Ethernet.localIP());
Serial.println(); Serial.println();
Serial.println("Connecting to:"); Serial.print("Connecting to: ");
Serial.print(config.address); Serial.print(config.address);
Serial.print(":"); Serial.print(":");
Serial.println(config.port); Serial.println(config.port);
@ -85,6 +89,10 @@ void setup(void) {
telemetry["device"] = serial; telemetry["device"] = serial;
// payload["id"] = serverName; // payload["id"] = serverName;
#if USE_MQTT
clientMQTT.setServer(config.address, 1883);
#endif
} }
void loop(void) { void loop(void) {
@ -107,7 +115,11 @@ void loop(void) {
temp["raw"] = tempReading; temp["raw"] = tempReading;
temp["volts"] = tempVoltage; temp["volts"] = tempVoltage;
#if USE_MQTT
publishData(config, telemetry);
#else
postData(config, telemetryURL, telemetry); postData(config, telemetryURL, telemetry);
#endif
if (counter == 6 * 120) { // Update clock every 6 times * 10 sec * 120 minutes = 2 hrs if (counter == 6 * 120) { // Update clock every 6 times * 10 sec * 120 minutes = 2 hrs
timeClient.update(); timeClient.update();
@ -122,6 +134,22 @@ void loop(void) {
delay(postDelay); delay(postDelay);
} }
#if USE_MQTT
void publishData(const netConfig &mqtt, const DynamicJsonDocument &json) {
if (clientMQTT.connect(serial, "freedcs", "password")) {
char buffer[256];
serializeJson(json, buffer);
clientMQTT.publish(serial, buffer);
#if DEBUG_TO_SERIAL
Serial.println("DEBUG: MQTT PUBLISH>>>");
serializeJsonPretty(json, Serial);
Serial.println("\n<<<");
#endif
}
}
#endif
void postData(const netConfig &postAPI, const String &URL, const DynamicJsonDocument &json) { void postData(const netConfig &postAPI, const String &URL, const DynamicJsonDocument &json) {
if (EthernetClient client = client.connect(postAPI.address, postAPI.port)) { if (EthernetClient client = client.connect(postAPI.address, postAPI.port)) {
client.print("POST "); client.print("POST ");
@ -140,7 +168,7 @@ void postData(const netConfig &postAPI, const String &URL, const DynamicJsonDocu
client.stop(); client.stop();
#if DEBUG_TO_SERIAL #if DEBUG_TO_SERIAL
Serial.println("DEBUG: >>>"); Serial.println("DEBUG: HTTP POST>>>");
serializeJsonPretty(json, Serial); serializeJsonPretty(json, Serial);
Serial.println("\n<<<"); Serial.println("\n<<<");
#endif #endif

View File

@ -32,18 +32,35 @@ services:
ports: ports:
- "127.0.0.1:5432:5432" - "127.0.0.1:5432:5432"
# mosquitto simple deployment
# mqtt:
# <<: *service_default
# # image: vernemq/vernemq
# # environment:
# # DOCKER_VERNEMQ_ALLOW_ANONYMOUS: "on"
# # DOCKER_VERNEMQ_ACCEPT_EULA: "yes"
# image: eclipse-mosquitto
# networks:
# - net
# ports:
# - "1883:1883"
# - "9001:9001"
rabbitmq: rabbitmq:
<<: *service_default <<: *service_default
image: rabbitmq:3-management image: rabbitmq:3-management-alpine
environment: environment:
RABBITMQ_DEFAULT_VHOST: "freedcs" # RABBITMQ_DEFAULT_VHOST: "freedcs"
RABBITMQ_DEFAULT_USER: "freedcs" RABBITMQ_DEFAULT_USER: "freedcs"
RABBITMQ_DEFAULT_PASS: "password" RABBITMQ_DEFAULT_PASS: "password"
volumes:
- ./rabbitmq/enabled_plugins:/etc/rabbitmq/enabled_plugins
networks: networks:
- net - net
ports: ports:
- "15672:15672" - "1883:1883"
- "5672:5672" - "5672:5672"
- "15672:15672"
edge: edge:
<<: *service_default <<: *service_default

View File

@ -0,0 +1 @@
[rabbitmq_management,rabbitmq_mqtt].