import sqlite3 def get_gui_radiator_data(topic): return __storage__().get_gui_radiator_data(topic) def set_gui_radiator_data(topic, away_mode, summer_mode, user_temperatur_setpoint): return __storage__().store_gui_radiator_data(topic, away_mode, summer_mode, user_temperatur_setpoint) class __storage__(object): def __init__(self): self.conn = sqlite3.connect("database.db") self.c = self.conn.cursor() with self.conn: self.c.execute("""CREATE TABLE IF NOT EXISTS gui_radiator ( topic text PRIMARY KEY, away_mode integer, summer_mode integer, user_temperatur_setpoint real )""") def store_gui_radiator_data(self, topic, away_mode, summer_mode, user_temperatur_setpoint): data = [topic, away_mode, summer_mode, user_temperatur_setpoint] try: with self.conn: self.c.execute( 'INSERT INTO gui_radiator VALUES (?, ?, ?, ?)', data) except sqlite3.IntegrityError: data = [away_mode, summer_mode, user_temperatur_setpoint] db_data = self.get_gui_radiator_data(topic) if db_data != data: with self.conn: self.c.execute( 'UPDATE gui_radiator SET away_mode = ?, summer_mode = ?, user_temperatur_setpoint = ? WHERE topic = ?', data + [topic]) def get_gui_radiator_data(self, topic): """ returns a list [away_mode, summer_mode, user_temperatur_setpoint] or [None, None, None]""" self.c.execute("SELECT * FROM gui_radiator WHERE topic=?", (topic, )) data = self.c.fetchone() if data is not None: data = list(data) data[1] = data[1] == 1 data[2] = data[2] == 1 return data[1:] else: return [None, None, None] def __del__(self): self.conn.close()