tibber-influx/pulse.py
2023-09-13 22:53:03 +02:00

72 lines
No EOL
1.8 KiB
Python

# -*- coding: utf-8 -*-
import os
import sys
import time
import tibber.const
import asyncio
import aiohttp
import tibber
from influxdb_client import InfluxDBClient
from influxdb_client.client.write_api import SYNCHRONOUS
from DataPoints import Pulse
import logging
TOKEN=os.getenv('TOKEN', '')
TIBBERTOKEN=os.getenv('TIBBERTOKEN', '')
URL = os.getenv('URL',"" )
BUCKET = os.getenv('BUCKET',"tibber" )
ORG = os.getenv('ORG',"Default" )
#logging
logger = logging.getLogger("TibberInflux")
formatter = logging.Formatter(
'%(asctime)s - %(name)s - %(levelname)s - %(message)s')
ch=logging.StreamHandler(sys.stdout)
#fh = logging.FileHandler('log.log')
ch.setFormatter(formatter)
#fh.setFormatter(formatter)
logger.addHandler(ch)
#logger.addHandler(fh)
logger.setLevel(logging.INFO)
__version__ = "v0.1.1"
logger.info(__version__)
client = InfluxDBClient(url=URL, token=TOKEN, org=ORG)
write_api = client.write_api(write_options=SYNCHRONOUS)
query_api = client.query_api()
def _incoming(pkg):
try:
data = pkg.get("data")
if data is None:
exit(1)
p = Pulse(data).get_datapoint()
write_api.write(record=p, bucket=BUCKET)
logger.info(p)
return True
except:
exit(1)
async def run():
async with aiohttp.ClientSession() as session:
if session.closed:
logger.error("session closed")
exit(1)
tibber_connection = tibber.Tibber(TIBBERTOKEN, websession=session, user_agent="python")
await tibber_connection.update_info()
home = tibber_connection.get_homes()[0]
await home.rt_subscribe(_incoming)
timeout = time.time() + 3600 # Set a timeout for 3600 seconds (1 hour)
while time.time() < timeout:
await asyncio.sleep(2)
loop = asyncio.get_event_loop()
loop.run_until_complete(run())
exit(42)