#!/usr/bin/env python3 """ common functions and stuff """ import logging import os import sys import warnings from datetime import datetime # Because of https://github.com/urllib3/urllib3/issues/3020 # Ignore "not using openssl"-error from urllib3. From https://gist.github.com/fire015/f9482919434e57af8bbd0dbc24ecaa9e warnings.filterwarnings("ignore", module="urllib3") # Get env var def env(var_name, default=None): value = os.getenv(var_name) if value is not None: return value if default is not None: return default print(f"Error: Could not find environment variable '{var_name}'") print("That variable is required for running this program.") sys.exit(1) QUEUE = bool(env("el_QUEUE", False)) name = os.path.splitext(os.path.split(sys.argv[0])[-1])[0] log = logging.getLogger(__name__) log.setLevel(logging.INFO) logging.basicConfig(format="%(name)s: %(levelname)s %(message)s") # Use queue or postgres if QUEUE is True: log.debug("Importing dbi from queue") from .queue import dbi else: log.debug("Importing dbi from postgres") from .postgres import dbi # Insert state def statein(sensor, value, device_class, unit, **kwargs): """Insert new state in db""" verbose = bool(kwargs["verbose"]) if "verbose" in kwargs else False sql = """INSERT INTO states (sensor_id, value, device_class, unit, time) SELECT sensors.id, %s, %s, %s, %s FROM sensors WHERE sensors.name = %s;""" values = (value, device_class, unit, datetime.utcnow(), sensor) log.debug("dbi(" + sql + "," + str(values) + ")") dbi(sql, values, verbose=verbose)