ConstError in tiramisu/error.py
[tiramisu.git] / tiramisu / storage / dictionary / storage.py
1 # -*- coding: utf-8 -*-
2 "default plugin for cache: set it in a simple dictionary"
3 # Copyright (C) 2013 Team tiramisu (see AUTHORS for all contributors)
4 #
5 # This program is free software; you can redistribute it and/or modify
6 # it under the terms of the GNU General Public License as published by
7 # the Free Software Foundation; either version 2 of the License, or
8 # (at your option) any later version.
9 #
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 # GNU General Public License for more details.
14 #
15 # You should have received a copy of the GNU General Public License
16 # along with this program; if not, write to the Free Software
17 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18 #
19 # ____________________________________________________________
20
21
22 from tiramisu.i18n import _
23 from tiramisu.error import ConfigError
24
25
26 class Setting(object):
27     pass
28
29
30 setting = Setting()
31
32
33 def list_sessions():
34     return []
35
36
37 def delete_session(session_id):
38     raise ConfigError(_('dictionary storage cannot delete session'))
39
40
41 class Storage(object):
42     __slots__ = tuple()
43     storage = 'dictionary'
44
45     def __init__(self, session_id, is_persistent):
46         if is_persistent:
47             raise ValueError(_('a dictionary cannot be persistent'))
48
49
50 class Cache(object):
51     __slots__ = ('_cache',)
52     key_is_path = False
53
54     def __init__(self):
55         self._cache = {}
56
57     def setcache(self, cache_type, path, val, time):
58         self._cache[path] = (val, time)
59
60     def getcache(self, cache_type, path, exp):
61         value, created = self._cache[path]
62         if exp < created:
63             return True, value
64         return False, None
65
66     def hascache(self, cache_type, path):
67         """ path is in the cache
68
69         :param cache_type: value | property
70         :param path: the path's option
71         """
72         return path in self._cache
73
74     def reset_expired_cache(self, cache_type, exp):
75         keys = self._cache.keys()
76         for key in keys:
77             val, created = self._cache[key]
78             if exp > created:
79                 del(self._cache[key])
80
81     def reset_all_cache(self, cache_type):
82         "empty the cache"
83         self._cache.clear()
84
85     def get_cached(self, cache_type, context):
86         """return all values in a dictionary
87         example: {'path1': ('value1', 'time1'), 'path2': ('value2', 'time2')}
88         """
89         return self._cache