X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/21fb64ae6ee29e909e791156679604233b61c725..e907efa7d02378ca6e4cbbcfacd25054faacf3bc:/forum/settings/base.py diff --git a/forum/settings/base.py b/forum/settings/base.py index 08f3ea8..cc706bc 100644 --- a/forum/settings/base.py +++ b/forum/settings/base.py @@ -1,14 +1,19 @@ import django.dispatch -from django.utils.encoding import force_unicode +from django.utils.encoding import force_unicode, smart_unicode +from datetime import datetime, timedelta +import logging + +TMP_MINICACHE_SECONDS = 5 class SettingSet(list): - def __init__(self, name, title, description, weight=1000, markdown=False): + def __init__(self, name, title, description, weight=1000, markdown=False, can_preview=False): self.name = name self.title = title self.description = description self.weight = weight self.markdown = markdown - + self.can_preview = can_preview + class BaseSetting(object): @classmethod @@ -23,29 +28,47 @@ class BaseSetting(object): self.default = default self.field_context = field_context or {} + self._temp = None + if set is not None: + self.set = set + if not set.name in Setting.sets: Setting.sets[set.name] = set Setting.sets[set.name].append(self) + def __str__(self): + return str(self.value) + def __unicode__(self): - return unicode(self.value) + return smart_unicode(self.value) @property def value(self): + if self._temp: + v, exp = self._temp + if exp + timedelta(seconds=TMP_MINICACHE_SECONDS) > datetime.now(): + return v + from forum.models import KeyValue try: kv = KeyValue.objects.get(key=self.name) - except: - kv = KeyValue(key=self.name, value=self._parse(self.default)) - kv.save() - - return kv.value + v = kv.value + self._temp = (v, datetime.now() + timedelta(seconds=TMP_MINICACHE_SECONDS)) + return v + except KeyValue.DoesNotExist: + self._temp = (self.default, datetime.now() + timedelta(seconds=TMP_MINICACHE_SECONDS)) + self.save(self.default) + except Exception, e: + logging.error("Error retrieving setting from database (%s): %s" % (self.name, str(e))) + + return self.default def set_value(self, new_value): new_value = self._parse(new_value) + self._temp = None self.save(new_value) def save(self, value): @@ -53,8 +76,11 @@ class BaseSetting(object): try: kv = KeyValue.objects.get(key=self.name) - except: + except KeyValue.DoesNotExist: kv = KeyValue(key=self.name) + except Exception, e: + logging.error("Error saving setting to database (%s): %s" % (self.name, str(e))) + return kv.value = value kv.save() @@ -63,6 +89,15 @@ class BaseSetting(object): self.set_value(self.default) def _parse(self, value): + if not isinstance(value, self.base_type): + try: + return self.base_type(value) + except: + pass + return value + +class AnyTypeSetting(BaseSetting): + def _parse(self, value): return value @@ -71,12 +106,16 @@ class Setting(object): sets = {} def __new__(cls, name, default, set=None, field_context=None): + if default is None: + return AnyTypeSetting(name, default, set, field_context) + deftype = type(default) if deftype in Setting.emulators: emul = Setting.emulators[deftype] else: - emul = type(deftype.__name__ + cls.__name__, (BaseSetting,), {}) + emul = type(deftype.__name__ + cls.__name__, (BaseSetting,), {'base_type': deftype}) + fns = [n for n, f in [(p, getattr(deftype, p)) for p in dir(deftype) if not p in dir(cls)] if callable(f)] for n in fns: @@ -85,5 +124,3 @@ class Setting(object): Setting.emulators[deftype] = emul return emul(name, default, set, field_context) - -