import threading
import pickle
from datetime import datetime
-from pprint import pprint
# maximum lifetime of cached data (in seconds)
MAX_CACHE_TTL = 60 * 60
cache = {}
lock = threading.RLock()
+
+ def __init__(self, filename=None):
+ if filename:
+ self.load_from_file(filename)
def add(self, key, value, ttl = MAX_CACHE_TTL):
with self.lock:
def get(self, key):
data = self.cache.get(key)
- if not data or data.is_expired():
- return None
- return data.get_data()
+ if not data:
+ data = None
+ elif data.is_expired():
+ self.pop(key)
+ data = None
+ else:
+ data = data.get_data()
+ return data
+
+ def pop(self, key):
+ if key in self.cache:
+ self.cache.pop(key)
def dump(self):
result = {}