aboutsummaryrefslogtreecommitdiffstats
path: root/scripts/neohub.py
diff options
context:
space:
mode:
authorDennis Eriksen <d@ennis.no>2023-03-29 21:20:40 +0200
committerDennis Eriksen <d@ennis.no>2023-03-29 21:20:44 +0200
commitb561663aba8c69b30ff14fb985df4cbf28ef0e6a (patch)
tree67e7e50f7310e27114e03af08f15a40e89409e73 /scripts/neohub.py
parententsoe has new api-url (diff)
downloadenergyscripts-b561663aba8c69b30ff14fb985df4cbf28ef0e6a.tar.gz
adding user/pass for mqtt, made a service for neohub
Diffstat (limited to 'scripts/neohub.py')
-rw-r--r--scripts/neohub.py25
1 files changed, 13 insertions, 12 deletions
diff --git a/scripts/neohub.py b/scripts/neohub.py
index 4fd3a16..7ef8b77 100644
--- a/scripts/neohub.py
+++ b/scripts/neohub.py
@@ -2,6 +2,7 @@
''' 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
@@ -10,8 +11,9 @@ import common
neohub_ip = os.environ['el_neohub_ip']
neohub_port = os.environ['el_neohub_port']
+SLEEP = 120 # Sleep between runs
-async def run():
+async def call_neohub():
''' async runner! w00p '''
# Legacy connection
hub = neohub.NeoHub(neohub_ip, int(neohub_port))
@@ -20,7 +22,7 @@ async def run():
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}")
+ #print(f"Temperature in zone {device.name}: {device}")
values = (
datetime.utcnow(),
device.time,
@@ -44,21 +46,20 @@ async def run():
temperature)
VALUES(%s, %s, %s, %s, %s, %s, %s, %s, %s)"""
- common.dbi(sql, values)
-
+ common.dbi(sql, values, verbose=True)
sql = """INSERT INTO mqtt_temps
- (name,
+ (sensor_id,
temperature,
- time,
- room)
- SELECT 'neohub', %s, %s, sensors.room
+ time)
+ SELECT sensors.id, %s, %s
FROM sensors
WHERE sensors.name = 'neohub'"""
values = (device.temperature, datetime.utcnow())
- common.dbi(sql, values)
-
-
+ common.dbi(sql, values, verbose=True)
-asyncio.run(run())
+# Loop it forever
+while True:
+ asyncio.run(call_neohub())
+ time.sleep(SLEEP)