123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051 |
- 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()
|