2022-05-09 09:42:42 +02:00
|
|
|
#include <InfluxDbClient.h> // from bib manager
|
2019-08-04 12:08:31 +02:00
|
|
|
|
2022-05-15 22:34:36 +02:00
|
|
|
#include "config_user.h"
|
|
|
|
|
2022-05-09 09:42:42 +02:00
|
|
|
// Data point
|
2022-05-15 22:34:36 +02:00
|
|
|
Point sensor(DEVICE_NAME);
|
2022-05-09 09:42:42 +02:00
|
|
|
|
|
|
|
// Init variables to influxdb config - doesn't talk to database
|
|
|
|
InfluxDBClient client(INFLUXDB_URL, INFLUXDB_ORG, INFLUXDB_BUCKET, INFLUXDB_TOKEN);
|
2018-06-23 20:13:33 +02:00
|
|
|
|
2019-08-04 12:08:31 +02:00
|
|
|
void influxdb_begin() {
|
2022-05-09 09:42:42 +02:00
|
|
|
|
|
|
|
// Check server connection
|
|
|
|
if (client.validateConnection()) {
|
|
|
|
// success
|
|
|
|
#ifdef DEBUG
|
|
|
|
Serial.print("InfluxDB connect success\n");
|
|
|
|
#endif
|
|
|
|
} else {
|
|
|
|
// fail
|
|
|
|
#ifdef DEBUG
|
|
|
|
Serial.print("InfluxDB connect failed\n");
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2019-08-04 12:08:31 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void pushToInfluxDB(String device, float sensorValues[]) {
|
2018-07-12 22:30:30 +02:00
|
|
|
|
2019-02-02 13:58:47 +01:00
|
|
|
if (!(isnan(sensorValues[SENSOR_TEMPERATURE])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("temperature", sensorValues[SENSOR_TEMPERATURE]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
if (!(isnan(sensorValues[SENSOR_HUMIDITY])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("humidity", sensorValues[SENSOR_HUMIDITY]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
if (!(isnan(sensorValues[SENSOR_LIGHT])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("light", sensorValues[SENSOR_LIGHT]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
if (!(isnan(sensorValues[SENSOR_WINDSPEED])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("windspeed", sensorValues[SENSOR_WINDSPEED]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
if (!(isnan(sensorValues[SENSOR_PRESSURE])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("pressure", sensorValues[SENSOR_PRESSURE]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
if (!(isnan(sensorValues[SENSOR_BAT_VOLTAGE])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("batvoltage", sensorValues[SENSOR_BAT_VOLTAGE]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
if (!(isnan(sensorValues[SENSOR_ESAVEMODE])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("esavemode", sensorValues[SENSOR_ESAVEMODE]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
if (!(isnan(sensorValues[SENSOR_BATCHARGESTATE])))
|
|
|
|
{
|
2022-05-09 09:42:42 +02:00
|
|
|
sensor.clearFields();
|
|
|
|
sensor.addField("batchargestate", sensorValues[SENSOR_BATCHARGESTATE]);
|
|
|
|
_writePoint();
|
2019-02-02 13:58:47 +01:00
|
|
|
}
|
|
|
|
|
2022-05-09 09:42:42 +02:00
|
|
|
}
|
2019-01-27 16:29:58 +01:00
|
|
|
|
2022-05-09 09:42:42 +02:00
|
|
|
void _writePoint() {
|
|
|
|
|
|
|
|
// wait unitl ready
|
2018-07-12 22:30:30 +02:00
|
|
|
do {
|
2022-05-09 09:42:42 +02:00
|
|
|
#ifdef DEBUG
|
|
|
|
Serial.print("InfluxDB: waiting for write ready\n");
|
|
|
|
#endif
|
|
|
|
} while (client.canSendRequest() == false);
|
|
|
|
|
|
|
|
// Write point
|
|
|
|
if (!client.writePoint(sensor)) {
|
|
|
|
#ifdef DEBUG
|
|
|
|
Serial.print("InfluxDB write failed: ");
|
|
|
|
Serial.println(client.getLastErrorMessage());
|
|
|
|
Serial.print("\nErrorcode: ");
|
|
|
|
Serial.println(client.getLastStatusCode());
|
|
|
|
Serial.print("\n");
|
|
|
|
#endif
|
|
|
|
} else {
|
|
|
|
#ifdef DEBUG
|
|
|
|
Serial.print("InfluxDB write done\n");
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2019-02-02 14:59:00 +01:00
|
|
|
}
|