#!/usr/bin/python3 ''' Get stuff from neohub! This is mostly the usage-example from https://gitlab.com/neohubapi/neohubapi/ ''' import os import time import asyncio from datetime import datetime import neohubapi.neohub as neohub import common neohub_ip = os.environ['el_neohub_ip'] neohub_port = os.environ['el_neohub_port'] SLEEP = 120 # Sleep between runs async def call_neohub(): ''' async runner! w00p ''' # Legacy connection hub = neohub.NeoHub(neohub_ip, int(neohub_port)) # Or, for a websocket connection: # hub = neohub.Neohub(port=4243, token='xxx-xxxxxxx') system = await hub.get_system() hub_data, devices = await hub.get_live_data() for device in devices['thermostats']: #print(f"Temperature in zone {device.name}: {device}") values = ( datetime.utcnow(), device.time, device.device_id, device.away, device.heat_mode, device.heat_on, device.current_floor_temperature, device.target_temperature, device.temperature) sql = """INSERT INTO neohub (timestamp, time, device_id, away, heat_mode, heat_on, current_floor_temperature, target_temperature, temperature) VALUES(%s, %s, %s, %s, %s, %s, %s, %s, %s)""" common.dbi(sql, values, verbose=True) sql = """INSERT INTO mqtt_temps (sensor_id, temperature, time) SELECT sensors.id, %s, %s FROM sensors WHERE sensors.name = 'neohub'""" values = (device.temperature, datetime.utcnow()) common.dbi(sql, values, verbose=True) # Loop it forever while True: asyncio.run(call_neohub()) time.sleep(SLEEP)