2021-12-07 03:52:43 +00:00
|
|
|
|
2021-12-06 04:19:39 +00:00
|
|
|
// FARM DATA RELAY SYSTEM
|
|
|
|
//
|
|
|
|
// GATEWAY 2.000
|
2021-12-06 17:36:18 +00:00
|
|
|
// This is still in progress. Stay tuned!
|
2021-12-06 04:19:39 +00:00
|
|
|
//
|
|
|
|
// Developed by Timm Bogner (bogner1@gmail.com) for Sola Gratia Farm in Urbana, Illinois, USA.
|
2021-12-06 17:36:18 +00:00
|
|
|
//
|
2021-12-06 04:19:39 +00:00
|
|
|
|
|
|
|
#if defined(ESP8266)
|
|
|
|
#include <ESP8266WiFi.h>
|
|
|
|
#include <espnow.h>
|
|
|
|
#elif defined(ESP32)
|
|
|
|
#include <esp_now.h>
|
|
|
|
#include <WiFi.h>
|
|
|
|
#include <esp_wifi.h>
|
|
|
|
#endif
|
|
|
|
#include "fdrs_config.h"
|
|
|
|
#include <ArduinoJson.h>
|
|
|
|
#include "DataReading.h"
|
|
|
|
#include <PubSubClient.h>
|
|
|
|
#include "fdrs_functions.h"
|
2021-12-07 03:52:43 +00:00
|
|
|
#include <LoRa.h>
|
2021-12-06 04:19:39 +00:00
|
|
|
|
2021-12-07 03:52:43 +00:00
|
|
|
#ifdef USE_WIFI
|
2021-12-06 17:36:18 +00:00
|
|
|
const char* ssid = WIFI_NET;
|
|
|
|
const char* password = WIFI_PASS;
|
|
|
|
const char* mqtt_server = MQTT_ADDR;
|
2021-12-07 03:52:43 +00:00
|
|
|
#endif
|
2021-12-07 17:36:45 +00:00
|
|
|
|
|
|
|
|
2021-12-06 04:19:39 +00:00
|
|
|
void setup() {
|
2021-12-08 03:45:33 +00:00
|
|
|
#if defined(ESP8266)
|
|
|
|
Serial.begin(115200);
|
|
|
|
#elif defined(ESP32)
|
|
|
|
Serial.begin(115200, SERIAL_8N1, RXD2, TXD2);
|
|
|
|
#endif
|
2021-12-06 04:19:39 +00:00
|
|
|
begin_espnow();
|
|
|
|
#ifdef USE_WIFI
|
|
|
|
delay(10);
|
|
|
|
WiFi.begin(ssid, password);
|
|
|
|
while (WiFi.status() != WL_CONNECTED) {
|
|
|
|
delay(500);
|
|
|
|
}
|
|
|
|
client.setServer(mqtt_server, 1883);
|
|
|
|
client.setCallback(mqtt_callback);
|
|
|
|
#endif
|
2021-12-07 03:52:43 +00:00
|
|
|
#ifdef USE_LORA
|
|
|
|
SPI.begin(SCK, MISO, MOSI, SS);
|
|
|
|
LoRa.setPins(SS, RST, DIO0);
|
|
|
|
if (!LoRa.begin(BAND)) {
|
|
|
|
while (1);
|
|
|
|
}
|
|
|
|
#endif
|
2021-12-06 04:19:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void loop() {
|
2022-01-05 00:02:12 +00:00
|
|
|
if (millis() > timeESPNOWG) {
|
|
|
|
timeESPNOWG += ESPNOWG_DELAY;
|
|
|
|
if (lenESPNOWG > 0) releaseESPNOW(0);
|
|
|
|
}
|
|
|
|
if (millis() > timeESPNOW1) {
|
|
|
|
timeESPNOW1 += ESPNOW1_DELAY;
|
|
|
|
if (lenESPNOW1 > 0) releaseESPNOW(1);
|
|
|
|
}
|
|
|
|
if (millis() > timeESPNOW2) {
|
|
|
|
timeESPNOW2 += ESPNOW2_DELAY;
|
|
|
|
if (lenESPNOW2 > 0) releaseESPNOW(2);
|
|
|
|
}
|
|
|
|
if (millis() > timeSERIAL) {
|
|
|
|
//Serial.println("timeSERIAL tripped: " + String(lenSERIAL));
|
|
|
|
timeSERIAL += SERIAL_DELAY;
|
|
|
|
if (lenSERIAL > 0) releaseSerial();
|
|
|
|
}
|
|
|
|
if (millis() > timeMQTT) {
|
|
|
|
timeMQTT += MQTT_DELAY;
|
|
|
|
if (lenMQTT > 0) releaseMQTT();
|
|
|
|
}
|
|
|
|
if (millis() > timeLORA) {
|
|
|
|
timeLORA += LORA_DELAY;
|
|
|
|
if (lenLORA > 0) releaseLoRa();
|
|
|
|
}
|
|
|
|
|
2021-12-06 04:19:39 +00:00
|
|
|
while (Serial.available()) {
|
|
|
|
getSerial();
|
|
|
|
}
|
2021-12-07 03:52:43 +00:00
|
|
|
#ifdef USE_LORA
|
|
|
|
int packetSize = LoRa.parsePacket();
|
|
|
|
if (packetSize)
|
|
|
|
{
|
|
|
|
LoRa.readBytes((uint8_t *)&theData, packetSize);
|
|
|
|
ln = packetSize;
|
|
|
|
newData = 6;
|
|
|
|
}
|
2022-01-05 00:02:12 +00:00
|
|
|
#endif
|
|
|
|
#ifdef USE_WIFI
|
|
|
|
if (!client.connected()) {
|
|
|
|
reconnect();
|
|
|
|
}
|
|
|
|
client.loop();
|
2021-12-07 03:52:43 +00:00
|
|
|
#endif
|
|
|
|
if (newData) {
|
2021-12-06 04:19:39 +00:00
|
|
|
switch (newData) {
|
|
|
|
case 1: //ESP-NOW #1
|
2021-12-06 17:36:18 +00:00
|
|
|
ESPNOW1_ACT
|
2021-12-06 04:19:39 +00:00
|
|
|
break;
|
|
|
|
case 2: //ESP-NOW #2
|
2021-12-06 17:36:18 +00:00
|
|
|
ESPNOW2_ACT
|
2021-12-06 04:19:39 +00:00
|
|
|
break;
|
|
|
|
case 3: //ESP-NOW General
|
2021-12-06 17:36:18 +00:00
|
|
|
ESPNOWG_ACT
|
2021-12-06 04:19:39 +00:00
|
|
|
break;
|
|
|
|
case 4: //Serial
|
2021-12-06 17:36:18 +00:00
|
|
|
SERIAL_ACT
|
2021-12-06 04:19:39 +00:00
|
|
|
break;
|
|
|
|
case 5: //MQTT
|
2021-12-06 17:36:18 +00:00
|
|
|
MQTT_ACT
|
2021-12-06 04:19:39 +00:00
|
|
|
break;
|
2021-12-07 03:52:43 +00:00
|
|
|
case 6: //LoRa
|
|
|
|
LORA_ACT
|
|
|
|
break;
|
2021-12-06 04:19:39 +00:00
|
|
|
}
|
|
|
|
newData = 0;
|
|
|
|
}
|
|
|
|
}
|