feat: changed tibber library to tibber.py

This commit is contained in:
Jan-Ole Hübner 2024-05-13 18:30:16 +02:00
parent 4733fed169
commit 63e8cd271e
4 changed files with 46 additions and 88 deletions

View file

@ -1,46 +1,35 @@
import os
import requests
import sys
import tibber
from influxdb_client import InfluxDBClient
from influxdb_client.client.write_api import SYNCHRONOUS
from DataPoints import Price
import logging
TOKEN = os.getenv('TOKEN', '')
TIBBERTOKEN = os.getenv('TIBBERTOKEN', '')
URL = os.getenv('URL', "")
BUCKET = os.getenv('BUCKET', "tibber")
ORG = os.getenv('ORG', "Default")
TOKEN=os.getenv('TOKEN', '')
TIBBERTOKEN=os.getenv('TIBBERTOKEN', '')
URL = os.getenv('URL',"" )
BUCKET = os.getenv('BUCKET',"tibber" )
ORG = os.getenv('ORG',"Default" )
# URL of the Tibber API
url = 'https://api.tibber.com/v1-beta/gql'
# Request headers
headers = {
'authority': 'api.tibber.com',
'accept': 'application/json',
'authorization': f'Bearer {TIBBERTOKEN}',
'content-type': 'application/json',
'user-agent': 'python 3.10',
}
# GraphQL query
query = '{"query":"{ viewer { homes { currentSubscription { priceInfo { current { total } } } } } }"}'
# Logging configuration
logger = logging.getLogger("TibberInflux")
formatter = logging.Formatter(
'%(asctime)s - %(name)s - %(levelname)s - %(message)s')
ch = logging.StreamHandler(sys.stdout)
ch.setFormatter(formatter)
logger.addHandler(ch)
logger.setLevel(logging.INFO)
__version__ = "v0.3.0"
logger.info(__version__)
client = InfluxDBClient(url=URL, token=TOKEN, org=ORG)
write_api = client.write_api(write_options=SYNCHRONOUS)
query_api = client.query_api()
# Make the HTTP POST request
response = requests.post(url, headers=headers, data=query)
# Check for successful response
if response.status_code == 200:
# Print the response content (JSON data)
print(response.json())
else:
print(f'Error: HTTP {response.status_code}')
p = Price(response.json()).get_datapoint()
account = tibber.Account(TIBBERTOKEN)
home = account.homes[0]
p = Price(home.current_subscription.price_info.current).get_datapoint()
write_api.write(record=p, bucket=BUCKET)
logger.info(vars(p))