|
|
|
|
87
|
#
|
87
|
#
|
88
|
STORAGE_VERSION = 1
|
88
|
STORAGE_VERSION = 1
|
89
|
|
89
|
|
90
|
- def __init__(self, source_instance, cache_filename, load_all_on_init=False, callback_on_data_storage=None, max_age=None, store_none_value=False):
|
|
|
|
|
90
|
+ def __init__(self, source_instance, cache_filename, load_all_on_init=False, callback_on_data_storage=None, max_age=None, store_on_get=True):
|
91
|
self._source_instance = source_instance
|
91
|
self._source_instance = source_instance
|
92
|
self._cache_filename = cache_filename
|
92
|
self._cache_filename = cache_filename
|
93
|
self._load_all_on_init = load_all_on_init
|
93
|
self._load_all_on_init = load_all_on_init
|
94
|
self._callback_on_data_storage = callback_on_data_storage
|
94
|
self._callback_on_data_storage = callback_on_data_storage
|
95
|
self._max_age = max_age
|
95
|
self._max_age = max_age
|
96
|
- self._store_none_value = store_none_value
|
|
|
|
|
96
|
+ self._store_on_get = store_on_get
|
97
|
self._cached_props = None
|
97
|
self._cached_props = None
|
98
|
|
98
|
|
99
|
def get(self, key, default=None):
|
99
|
def get(self, key, default=None):
|
|
|
|
|
116
|
if self._key_filter(key) not in self._cached_props[self.DATA_TAG] or cache_old:
|
116
|
if self._key_filter(key) not in self._cached_props[self.DATA_TAG] or cache_old:
|
117
|
val = self._source_instance.get(key, None)
|
117
|
val = self._source_instance.get(key, None)
|
118
|
logger.debug("%s Loading property for '%s' from source instance (%s)", self.LOG_PREFIX, key, repr(val))
|
118
|
logger.debug("%s Loading property for '%s' from source instance (%s)", self.LOG_PREFIX, key, repr(val))
|
119
|
- if val or self._store_none_value:
|
|
|
|
|
119
|
+ if self._store_on_get:
|
120
|
tm = int(time.time())
|
120
|
tm = int(time.time())
|
121
|
logger.debug("Storing value=%s with timestamp=%d to chache", val, tm)
|
121
|
logger.debug("Storing value=%s with timestamp=%d to chache", val, tm)
|
122
|
self._cached_props[self.DATA_TAG][self._key_filter(key)] = val
|
122
|
self._cached_props[self.DATA_TAG][self._key_filter(key)] = val
|
|
|
|
|
132
|
logger.info("%s Key '%s' is not in cached_keys. Uncached data will be returned.", self.LOG_PREFIX, key)
|
132
|
logger.info("%s Key '%s' is not in cached_keys. Uncached data will be returned.", self.LOG_PREFIX, key)
|
133
|
return self._source_instance.get(key, default)
|
133
|
return self._source_instance.get(key, default)
|
134
|
|
134
|
|
|
|
135
|
+ def full_update(self):
|
|
|
136
|
+ self._load_source()
|
|
|
137
|
+ self._save_cache()
|
|
|
138
|
+
|
135
|
def keys(self):
|
139
|
def keys(self):
|
136
|
"""
|
140
|
"""
|
137
|
Method to get the available keys (from :data:`source_instance`).
|
141
|
Method to get the available keys (from :data:`source_instance`).
|
|
|
|
|
163
|
storage_version = True
|
167
|
storage_version = True
|
164
|
#
|
168
|
#
|
165
|
if not load_cache or uid or data_version or storage_version:
|
169
|
if not load_cache or uid or data_version or storage_version:
|
166
|
- if self._uid() is not None and uid:
|
|
|
167
|
- logger.debug("%s Source uid changed, ignoring previous cache data", self.LOG_PREFIX)
|
|
|
168
|
- if self._data_version() is not None and data_version:
|
|
|
169
|
- logger.debug("%s Data version increased, ignoring previous cache data", self.LOG_PREFIX)
|
|
|
170
|
- if storage_version:
|
|
|
171
|
- logger.debug("%s Storage version changed, ignoring previous cache data", self.LOG_PREFIX)
|
|
|
|
|
170
|
+ if load_cache:
|
|
|
171
|
+ if self._uid() is not None and uid:
|
|
|
172
|
+ logger.debug("%s Source uid changed, ignoring previous cache data", self.LOG_PREFIX)
|
|
|
173
|
+ if self._data_version() is not None and data_version:
|
|
|
174
|
+ logger.debug("%s Data version increased, ignoring previous cache data", self.LOG_PREFIX)
|
|
|
175
|
+ if storage_version:
|
|
|
176
|
+ logger.debug("%s Storage version changed, ignoring previous cache data", self.LOG_PREFIX)
|
172
|
self._cached_props = {self.AGE_TAG: {}, self.DATA_TAG: {}}
|
177
|
self._cached_props = {self.AGE_TAG: {}, self.DATA_TAG: {}}
|
173
|
if self._load_all_on_init:
|
178
|
if self._load_all_on_init:
|
174
|
self._load_source()
|
179
|
self._load_source()
|
|
|
|
|
191
|
return key
|
196
|
return key
|
192
|
|
197
|
|
193
|
def _load_source(self):
|
198
|
def _load_source(self):
|
|
|
199
|
+ if self._cached_props is None:
|
|
|
200
|
+ self._init_cache()
|
194
|
logger.debug('%s Loading all data from source - %s', self.LOG_PREFIX, repr(self._source_instance.keys()))
|
201
|
logger.debug('%s Loading all data from source - %s', self.LOG_PREFIX, repr(self._source_instance.keys()))
|
195
|
for key in self._source_instance.keys():
|
202
|
for key in self._source_instance.keys():
|
196
|
- val = self._source_instance.get(key)
|
|
|
197
|
- self._cached_props[self.DATA_TAG][self._key_filter(key)] = val
|
|
|
|
|
203
|
+ self._cached_props[self.DATA_TAG][self._key_filter(key)] = self._source_instance.get(key)
|
198
|
self._cached_props[self.AGE_TAG][self._key_filter(key)] = int(time.time())
|
204
|
self._cached_props[self.AGE_TAG][self._key_filter(key)] = int(time.time())
|
199
|
|
205
|
|
200
|
def _save_cache(self):
|
206
|
def _save_cache(self):
|