modular-weather-station/WeatherStation.ino

256 lines
5.3 KiB
Arduino
Raw Permalink Normal View History

/*
* ModularWeatherStation
*
* Copyright (C) 2021 Gergely Polonkai
* Author: Gergely POLONKAI <gergely@polonkai.eu>
*
* ModularWeatherStation 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.
*
* ModularWeatherStation 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/>.
*
* As additional permission under GNU GPL version 3 section 7, you may
* distribute non-source form of the Program without the copy of the
* GNU GPL normally required by section 4, provided you inform the
* receipents of GNU GPL by a written offer.
*
*/
#include <ESP8266WiFi.h>
#include <WiFiClient.h>
#include <ESP8266mDNS.h>
#include "config.h"
#ifdef DHT_TYPE
# include <DHT.h>
#endif // DHT_TYPE
#if defined(HAVE_BH1750) || defined(HAVE_BMP180)
# include <Wire.h>
#endif // defined(HAVE_BH1750) || defined(HAVE_BMP180)
#ifdef HAVE_BH1750
# include <BH1750.h>
#endif // HAVE_BH1750
#ifdef HAVE_BMP180
# include <Adafruit_BMP085.h>
#endif // HAVE_BMP180
2021-01-18 09:57:45 +00:00
char *negotiated_hostname = NULL;
bool hostname_verified = false;
MDNSResponder::hMDNSService mdns_service = NULL;
unsigned long last_update = 0;
#ifdef DHT_TYPE
DHT dht(DHT_PIN, DHT_TYPE);
#endif // DHT_TYPE
#ifdef HAVE_BH1750
BH1750 light;
#endif // HAVE_BH1750
#ifdef HAVE_BMP180
Adafruit_BMP085 bmp;
#endif // HAVE_BMP180
#if SYSTEM_MODE & MODE_PROM_PULL
#include "mode_pull.h"
PWSModePull mode(80);
#endif
void
stop()
{
while (1) {
delay(1000);
}
}
2021-01-18 09:57:45 +00:00
bool
set_station_hostname(const char *hostname)
{
if (hostname) {
WiFi.hostname(hostname);
}
return true;
}
void
host_probe_result(String hostname, bool result)
{
if (result == true) {
set_station_hostname(negotiated_hostname);
if (!hostname_verified) {
hostname_verified = true;
if (!mdns_service) {
mdns_service = MDNS.addService(0, "http", "tcp", 80);
if (mdns_service) {
MDNS.addServiceTxt(mdns_service, "port#", 80);
}
}
}
} else {
if (MDNSResponder::indexDomain(negotiated_hostname, "-", 0)) {
MDNS.setHostname(negotiated_hostname);
} else {
Serial.println("Failed to set mDNS hostname");
}
}
}
void
setup()
{
IPAddress address;
Serial.begin(9600);
WiFi.mode(WIFI_STA);
WiFi.begin(WIFI_SSID, WIFI_PASS);
while (WiFi.status() != WL_CONNECTED) {
delay(500);
Serial.println("Waiting for WiFi to connect...");
}
address = WiFi.localIP();
Serial.print("WiFi Address: ");
address.printTo(Serial);
Serial.println("");
2021-01-18 09:57:45 +00:00
MDNS.setHostProbeResultCallback(host_probe_result);
if ((!MDNSResponder::indexDomain(negotiated_hostname, 0, SYSTEM_NAME)) ||
2021-01-18 09:57:45 +00:00
(!MDNS.begin(negotiated_hostname))) {
Serial.println("Error setting up mDNS!");
stop();
}
mode.begin();
// Initialize sensors
#ifdef DHT_TYPE
dht.begin();
#endif // DHT_TYPE
#ifdef RAIN_PIN
pinMode(RAIN_PIN, INPUT);
#endif // RAIN_PIN
#if defined(HAVE_BMP180) || defined(HAVE_BH1750)
Wire.begin(I2C_SDA_PIN, I2C_SCL_PIN);
#endif // HAVE_BMP180 || HAVE_BH1750
#ifdef HAVE_BH1750
if (!light.begin()) {
Serial.println("Could not find the BH1750 sensor!");
stop();
}
#endif // HAVE_BH1750
#ifdef HAVE_BMP180
if (!bmp.begin()) {
Serial.println("Could not find the BMP180 sensor!");
stop();
}
#endif // HAVE_BMP180
Serial.println("All set, starting the loop.");
}
void
read_sensors()
{
#if defined(DHT_TYPE) || defined(HAVE_BMP180)
float temperature;
#endif
#ifdef DHT_TYPE
float humidity;
#endif
#ifdef RAIN_PIN
bool raining;
#endif
#ifdef HAVE_BH1750
float light_level;
#endif
#ifdef HAVE_BMP180
float pressure;
#endif
// Turn on the LED to indicate that were working
digitalWrite(LED_BUILTIN, LOW);
#if defined(DHT_TYPE)
temperature = dht.readTemperature();
humidity = dht.readHumidity();
#endif // DHT_TYPE
#ifdef RAIN_PIN
raining = (digitalRead(RAIN_PIN) == HIGH);
#endif
#ifdef HAVE_BH1750
light_level = light.readLightLevel();
#endif // HAVE_BH1750
#ifdef HAVE_BMP180
pressure = bmp.readPressure();
// If we have a DHT sensor, we already measured the temperature
# ifndef DHT_TYPE
temperature = bmp.readTemperature();
# endif // !DHT_TYPE
#endif // HAVE_BMP180
mode.sendValues(
#if defined(DHT_TYPE) || defined(HAVE_BMP180)
temperature,
#endif
#ifdef DHT_TYPE
humidity,
#endif
#ifdef RAIN_PIN
raining,
#endif
#ifdef HAVE_BH1750
light,
#endif
#ifdef HAVE_BMP180
pressure,
#endif
0);
// Turn off the LED to indicate work is finished
digitalWrite(LED_BUILTIN, HIGH);
}
void
loop()
{
unsigned long now = millis();
MDNS.update();
mode.loop();
if (now - last_update >= 5000) {
read_sensors();
last_update = now;
}
}