mirror of
https://github.com/1technophile/OpenMQTTGateway.git
synced 2026-02-19 16:21:44 +01:00
By building only the log level required into LOG_LEVEL Co-authored-by: Florian <1technophile@users.noreply.github.com>
82 lines
2.6 KiB
C++
82 lines
2.6 KiB
C++
/*
|
|
Theengs OpenMQTTGateway - We Unite Sensors in One Open-Source Interface
|
|
|
|
Act as a gateway between your 433mhz, infrared IR, BLE, LoRa signal and one interface like an MQTT broker
|
|
Send and receiving command by MQTT
|
|
|
|
DHT reading Addon
|
|
|
|
Copyright: (c)Florian ROBERT
|
|
|
|
Contributors:
|
|
- prahjister
|
|
- 1technophile
|
|
|
|
This file is part of OpenMQTTGateway.
|
|
|
|
OpenMQTTGateway is free software: you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
(at your option) any later version.
|
|
|
|
OpenMQTTGateway is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU General Public License for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
#include "User_config.h"
|
|
|
|
#ifdef ZsensorDHT
|
|
# include <DHT.h>
|
|
# include <DHT_U.h>
|
|
|
|
# include "TheengsCommon.h"
|
|
# include "config_DHT.h"
|
|
|
|
DHT dht(DHT_RECEIVER_GPIO, DHT_SENSOR_TYPE);
|
|
|
|
//Time used to wait for an interval before resending temp and hum
|
|
unsigned long timedht = 0;
|
|
|
|
void setupDHT() {
|
|
THEENGS_LOG_NOTICE(F("Reading DHT on pin: %d" CR), DHT_RECEIVER_GPIO);
|
|
}
|
|
|
|
void MeasureTempAndHum() {
|
|
if (millis() > (timedht + TimeBetweenReadingDHT)) { //retrieving value of temperature and humidity of the box from DHT every xUL
|
|
timedht = millis();
|
|
static float persistedh;
|
|
static float persistedt;
|
|
float h = dht.readHumidity();
|
|
// Read temperature as Celsius (the default)
|
|
float t = dht.readTemperature();
|
|
// Check if any reads failed and exit early (to try again).
|
|
if (isnan(h) || isnan(t)) {
|
|
THEENGS_LOG_ERROR(F("Failed to read from DHT sensor!" CR));
|
|
} else {
|
|
THEENGS_LOG_TRACE(F("Creating DHT buffer" CR));
|
|
StaticJsonDocument<JSON_MSG_BUFFER> DHTdataBuffer;
|
|
JsonObject DHTdata = DHTdataBuffer.to<JsonObject>();
|
|
if (h != persistedh || dht_always) {
|
|
DHTdata["hum"] = (float)h;
|
|
} else {
|
|
THEENGS_LOG_TRACE(F("Same hum don't send it" CR));
|
|
}
|
|
if (t != persistedt || dht_always) {
|
|
DHTdata["tempc"] = (float)t;
|
|
DHTdata["tempf"] = dht.convertCtoF(t);
|
|
} else {
|
|
THEENGS_LOG_TRACE(F("Same temp don't send it" CR));
|
|
}
|
|
DHTdata["origin"] = DHTTOPIC;
|
|
enqueueJsonObject(DHTdata);
|
|
}
|
|
persistedh = h;
|
|
persistedt = t;
|
|
}
|
|
}
|
|
#endif
|