weatherstation-influx/importer/import.py

50 lines
1.7 KiB
Python

HOST = "192.168.2.110"
PORT = 4223
UID = "DYC"
URL = "http://192.168.2.30:8086/write?db=mydb"
import logging
import time
import requests
from tinkerforge.ip_connection import IPConnection
from tinkerforge.bricklet_outdoor_weather import BrickletOutdoorWeather
log = logging.getLogger(__name__)
def asdf(type, identifier, **kwargs):
log.info(type, identifier, kwargs)
time_ns = time.time_ns()
data = []
for unit in kwargs:
data.append(f"{unit},type={type},identifier={identifier} value={kwargs[unit]} {time_ns}")
try:
r = requests.post(URL, data="\n".join(data))
log.info(r, r.text)
except Exception as e:
log.exception(e)
def cb_station(identifier, temperature, humidity, wind_speed, gust_speed, rain, wind_direction, battery_low):
asdf(type="station", identifier=identifier, temperature=temperature, humidity=humidity, wind_speed=wind_speed, gust_speed=gust_speed, rain=rain, wind_direction=wind_direction, battery_low=battery_low)
def cb_sensor(identifier, temperature, humidity):
asdf(type="sensor", identifier=identifier, temperature=temperature, humidity=humidity)
if __name__ == "__main__":
logging.basicConfig(format='%(asctime)s - %(name)s - %(levelname)s - %(message)s', level=logging.INFO)
log.info("starting…")
ipcon = IPConnection()
ow = BrickletOutdoorWeather(UID, ipcon)
ipcon.connect(HOST, PORT)
ow.set_station_callback_configuration(True)
ow.set_sensor_callback_configuration(True)
ow.register_callback(ow.CALLBACK_STATION_DATA, cb_station)
ow.register_callback(ow.CALLBACK_SENSOR_DATA, cb_sensor)
log.info("now we play the waiting game…")
while True:
try:
time.sleep(60*60)
except Exception:
log.warning("")
ipcon.disconnect()