feature: restructured Datapoints

This commit is contained in:
Jan-Ole Hübner 2023-09-02 22:39:52 +02:00
parent db34941c30
commit dd9ee96396
2 changed files with 51 additions and 54 deletions

24
DataPoints.py Normal file
View file

@ -0,0 +1,24 @@
from influxdb_client import Point
class Pulse:
label = str(__name__).lower()
def __init__(self,data):
measurement = data['liveMeasurement']
timestamp = measurement['timestamp']
power = measurement['power']
cost = measurement.get('accumulatedCost',None)
lastMeterConsumption = measurement['lastMeterConsumption']
tags = {self.label: ""}
fields = {
"power": float(power),
"lastMeterConsumption": float(lastMeterConsumption)
}
if cost is not None:
fields.update({'accumulatedCost':cost})
self.datapoint = {"fields": fields,
"tags": tags,
"measurement": "pulse",
"time": timestamp
}
def get_datapoint(self):
return Point(measurement_name=str(self.label)).from_dict(self.datapoint)

View file

@ -1,86 +1,59 @@
#!/usr/bin/python3
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
import os import os
import time import random
from dateutil.parser import parse
print("tibber_v001")
import tibber.const import tibber.const
import asyncio import asyncio
import aiohttp import aiohttp
import tibber import tibber
# settings from EnvionmentValue from influxdb_client import InfluxDBClient
from influxdb_client.client.write_api import SYNCHRONOUS
from DataPoints import Pulse
TOKEN=os.getenv('TOKEN', '') TOKEN=os.getenv('TOKEN', '')
TIBBERTOKEN=os.getenv('TIBBERTOKEN', '') TIBBERTOKEN=os.getenv('TIBBERTOKEN', '')
URL = os.getenv('URL',"" ) URL = os.getenv('URL',"" )
BUCKET = os.getenv('BUCKET',"tibber" ) BUCKET = os.getenv('BUCKET',"tibber" )
ORG = os.getenv('ORG',"Default" ) ORG = os.getenv('ORG',"Default" )
from influxdb_client import InfluxDBClient, Point __version__ = "v0.0.2"
from influxdb_client.client.write_api import SYNCHRONOUS print(f"tibber_{__version__}")
bucket = "Default"
client = InfluxDBClient(url=URL, token=TOKEN, org=ORG) client = InfluxDBClient(url=URL, token=TOKEN, org=ORG)
write_api = client.write_api(write_options=SYNCHRONOUS) write_api = client.write_api(write_options=SYNCHRONOUS)
query_api = client.query_api() query_api = client.query_api()
def _callback(pkg): def _incoming(pkg):
try: try:
data = pkg.get("data") data = pkg.get("data")
if data is None: if data is None:
return exit(1)
lm=data.get("liveMeasurement") p = Pulse(data).get_datapoint()
print(lm) write_api.write(record=p, bucket=BUCKET)
write_to_db(data) print(p)
return lm return True
except Exception as e: except:
raise e exit(1)
def write_to_db(data,bucket = BUCKET):
measurement = data['liveMeasurement']
timestamp = measurement['timestamp']
power = measurement['power']
lastMeterConsumption = measurement['lastMeterConsumption']
tags = {"adress":""}
fields = {
"power": float(power),
"lastMeterConsumption": float(lastMeterConsumption)
}
datapoint = {"fields": fields,
"tags": tags,
"measurement": "pulse",
time: timestamp
}
p = Point(measurement_name="pulse").from_dict(datapoint)
write_api.write(record=p, bucket=bucket)
async def run(): async def run():
async with aiohttp.ClientSession() as session: async with aiohttp.ClientSession() as session:
if session.closed:
print("session closed")
exit(1)
tibber_connection = tibber.Tibber(TIBBERTOKEN, websession=session, user_agent="python") tibber_connection = tibber.Tibber(TIBBERTOKEN, websession=session, user_agent="python")
await tibber_connection.update_info() await tibber_connection.update_info()
home = tibber_connection.get_homes()[0] home = tibber_connection.get_homes()[0]
try: try:
await home.rt_subscribe(_callback) await home.rt_subscribe(_incoming)
except:
raise Exception("Session gone") except:
exit(1)
while 1:
await asyncio.sleep(5)
while True:
await asyncio.sleep(4)
loop = asyncio.get_event_loop() loop = asyncio.get_event_loop()
try: loop.run_until_complete(run())
loop.run_until_complete(run())
except:
exit(1)