smok-serwis/smok-client

View on GitHub
smok/extras/sensors_database/pickling.py

Summary

Maintainability
A
0 mins
Test Coverage
F
38%
import os
import pickle
import typing as tp

from satella.coding import Monitor

from .base import BaseSensorDatabase
from smok.sensor.sensor import Sensor


class PicklingSensorDatabase(BaseSensorDatabase, Monitor):
    def __init__(self, path: str):
        super().__init__()
        Monitor.__init__(self)
        self.__path = path
        self.sensor_cache = {}
        if os.path.exists(path):
            try:
                with open(path, 'rb') as f_in:
                    self.__data = pickle.load(f_in)
            except pickle.UnpicklingError:
                self.__data = {}

    @Monitor.synchronized
    def get_sensor(self, fqts: str) -> Sensor:
        if fqts not in self.sensor_cache:
            sensor = Sensor(self.device, *self.__data[fqts])
            self.sensor_cache[fqts] = sensor
        return self.sensor_cache[fqts]

    @Monitor.synchronized
    def on_sensors_sync(self, sensors: tp.List[Sensor]):
        self.__data = {}
        for sensor in sensors:
            self.__data[sensor.fqts] = sensor.fqts, sensor.path, sensor.type_name
        self.__save()

    def get_all_sensors(self) -> tp.Iterator[Sensor]:
        for key in self.__data.keys():
            yield self.get_sensor(key)

    def __save(self):
        with open(self.__path, 'wb') as f_out:
            pickle.dump(self.__data, f_out, pickle.HIGHEST_PROTOCOL)