aboutsummaryrefslogblamecommitdiffstats
path: root/scripts/neohub.py
blob: 5c626063220b9fea794b86027abcb3f0b773c91a (plain) (tree)
1
2
3
4
5
6
7
8



                  
                             

                                 
                      


                                          
 








                                                             

                                                                                                                                                                                                   
                        


                  
#!/usr/bin/python3

import os
import asyncio
from datetime import datetime
import neohubapi.neohub as neohub

from common import dbi

neohub_ip = os.environ['el_neohub_ip']
neohub_port = os.environ['el_neohub_port']

async def run():
    # 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}")
        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)"
        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)
        dbi(sql, values)

asyncio.run(run())