forked from CGM_Public/pretix_original
Basic settings serialization and SettingsForm object
This commit is contained in:
@@ -1,4 +1,5 @@
|
|||||||
from django.forms.models import ModelFormMetaclass, BaseModelForm
|
from django.forms.models import ModelFormMetaclass, BaseModelForm
|
||||||
|
from django import forms
|
||||||
from django.utils import six
|
from django.utils import six
|
||||||
from versions.models import Versionable
|
from versions.models import Versionable
|
||||||
|
|
||||||
@@ -23,3 +24,21 @@ class VersionedModelForm(six.with_metaclass(ModelFormMetaclass, VersionedBaseMod
|
|||||||
with both versioned and non-versioned models.
|
with both versioned and non-versioned models.
|
||||||
"""
|
"""
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class SettingsForm(forms.Form):
|
||||||
|
"""
|
||||||
|
This form is meant to be used for modifying Event- or OrganizerSettings
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
|
self.obj = kwargs.pop('obj')
|
||||||
|
if 'initial' not in kwargs:
|
||||||
|
kwargs['initial'] = self.obj.settings
|
||||||
|
super().__init__(*args, **kwargs)
|
||||||
|
|
||||||
|
def save(self):
|
||||||
|
for name, field in self.fields.items():
|
||||||
|
value = self.cleaned_data[name]
|
||||||
|
if self.obj.settings.get(value, as_type=type(value)) != value:
|
||||||
|
self.obj.settings.set(name, value)
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
import json
|
||||||
|
|
||||||
|
|
||||||
DEFAULTS = {
|
DEFAULTS = {
|
||||||
'user_mail_required': 'False',
|
'user_mail_required': 'False',
|
||||||
'max_items_per_order': '10',
|
'max_items_per_order': '10',
|
||||||
@@ -27,17 +30,44 @@ class SettingsProxy:
|
|||||||
self._cached_obj[setting.key] = setting
|
self._cached_obj[setting.key] = setting
|
||||||
return self._cached_obj
|
return self._cached_obj
|
||||||
|
|
||||||
def get(self, key, default=None):
|
def _unserialize(self, value, as_type):
|
||||||
|
if isinstance(value, as_type):
|
||||||
|
return value
|
||||||
|
elif as_type == int:
|
||||||
|
return int(value)
|
||||||
|
elif as_type == float:
|
||||||
|
return float(value)
|
||||||
|
elif as_type == dict or as_type == list:
|
||||||
|
return json.loads(value)
|
||||||
|
elif as_type == bool:
|
||||||
|
return value == 'True'
|
||||||
|
return value
|
||||||
|
|
||||||
|
def _serialize(self, value):
|
||||||
|
if isinstance(value, str):
|
||||||
|
return value
|
||||||
|
elif isinstance(value, int) or isinstance(value, float) or isinstance(value, bool):
|
||||||
|
return str(value)
|
||||||
|
elif isinstance(value, list) or isinstance(value, bool):
|
||||||
|
return json.dumps(value)
|
||||||
|
raise TypeError('Unable to serialize %s into a setting.' % str(type(value)))
|
||||||
|
|
||||||
|
def get(self, key, default=None, as_type=str):
|
||||||
|
"""
|
||||||
|
Get a setting specified by key 'key'. Normally, settings are strings, but
|
||||||
|
if you put non-strings into the settings object, you can request unserialization
|
||||||
|
by specifying 'as_type'
|
||||||
|
"""
|
||||||
if key in self._cache():
|
if key in self._cache():
|
||||||
return self._cache()[key].value
|
return self._unserialize(self._cache()[key].value, as_type)
|
||||||
value = None
|
value = None
|
||||||
if self._parent:
|
if self._parent:
|
||||||
value = self._parent.settings.get(key)
|
value = self._parent.settings.get(key)
|
||||||
if value is None and key in DEFAULTS:
|
if value is None and key in DEFAULTS:
|
||||||
return DEFAULTS[key]
|
return self._unserialize(DEFAULTS[key], as_type)
|
||||||
if value is None and default is not None:
|
if value is None and default is not None:
|
||||||
return default
|
return self._unserialize(default, as_type)
|
||||||
return value
|
return self._unserialize(value, as_type)
|
||||||
|
|
||||||
def __getitem__(self, key):
|
def __getitem__(self, key):
|
||||||
return self.get(key)
|
return self.get(key)
|
||||||
@@ -59,7 +89,7 @@ class SettingsProxy:
|
|||||||
s = s.clone()
|
s = s.clone()
|
||||||
else:
|
else:
|
||||||
s = self._type(object=self._obj, key=key)
|
s = self._type(object=self._obj, key=key)
|
||||||
s.value = value
|
s.value = self._serialize(value)
|
||||||
s.save()
|
s.save()
|
||||||
self._cache()[key] = s
|
self._cache()[key] = s
|
||||||
|
|
||||||
@@ -108,8 +138,8 @@ class SettingsSandbox:
|
|||||||
def __delattr__(self, key):
|
def __delattr__(self, key):
|
||||||
del self._event.settings[self._convert_key(key)]
|
del self._event.settings[self._convert_key(key)]
|
||||||
|
|
||||||
def get(self, key, default=None):
|
def get(self, key, default=None, as_type=str):
|
||||||
return self._event.settings.get(self._convert_key(key), default)
|
return self._event.settings.get(self._convert_key(key), default=default, as_type=type)
|
||||||
|
|
||||||
def set(self, key, value):
|
def set(self, key, value):
|
||||||
self._event.settings.set(self._convert_key(key), value)
|
self._event.settings.set(self._convert_key(key), value)
|
||||||
|
|||||||
Reference in New Issue
Block a user