mirror of
https://github.com/daniviga/bite.git
synced 2025-04-20 22:41:18 +02:00
Add MQTT support on Arduino
This commit is contained in:
parent
bbb92100f8
commit
55e58680ac
@ -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
|
||||||
|
@ -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
|
||||||
|
1
docker/rabbitmq/enabled_plugins
Normal file
1
docker/rabbitmq/enabled_plugins
Normal file
@ -0,0 +1 @@
|
|||||||
|
[rabbitmq_management,rabbitmq_mqtt].
|
Loading…
x
Reference in New Issue
Block a user