2018-01-11 12:10:27 +00:00
|
|
|
import json
|
|
|
|
|
2018-01-12 07:43:26 +00:00
|
|
|
import ldap
|
2016-09-03 11:05:50 +00:00
|
|
|
from django.db import models
|
2018-01-22 03:38:40 +00:00
|
|
|
from django.db.utils import ProgrammingError, OperationalError
|
2018-01-11 12:10:27 +00:00
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from django.conf import settings
|
2018-08-07 10:11:46 +00:00
|
|
|
from django_auth_ldap.config import LDAPSearch, LDAPSearchUnion
|
2018-01-11 12:10:27 +00:00
|
|
|
|
2018-09-03 03:24:25 +00:00
|
|
|
from .utils import get_signer
|
|
|
|
|
|
|
|
signer = get_signer()
|
|
|
|
|
2018-01-11 12:10:27 +00:00
|
|
|
|
|
|
|
class SettingQuerySet(models.QuerySet):
|
|
|
|
def __getattr__(self, item):
|
|
|
|
instances = self.filter(name=item)
|
|
|
|
if len(instances) == 1:
|
|
|
|
return instances[0]
|
|
|
|
else:
|
|
|
|
return Setting()
|
|
|
|
|
|
|
|
|
|
|
|
class SettingManager(models.Manager):
|
|
|
|
def get_queryset(self):
|
|
|
|
return SettingQuerySet(self.model, using=self._db)
|
|
|
|
|
|
|
|
|
|
|
|
class Setting(models.Model):
|
|
|
|
name = models.CharField(max_length=128, unique=True, verbose_name=_("Name"))
|
|
|
|
value = models.TextField(verbose_name=_("Value"))
|
2018-01-20 14:22:09 +00:00
|
|
|
category = models.CharField(max_length=128, default="default")
|
2018-09-03 03:24:25 +00:00
|
|
|
encrypted = models.BooleanField(default=False)
|
2018-01-11 12:10:27 +00:00
|
|
|
enabled = models.BooleanField(verbose_name=_("Enabled"), default=True)
|
|
|
|
comment = models.TextField(verbose_name=_("Comment"))
|
|
|
|
|
|
|
|
objects = SettingManager()
|
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return self.name
|
|
|
|
|
2018-09-03 03:24:25 +00:00
|
|
|
def __getattr__(self, item):
|
2018-11-19 04:18:52 +00:00
|
|
|
default = getattr(settings, item, None)
|
|
|
|
try:
|
|
|
|
instances = self.__class__.objects.filter(name=item)
|
|
|
|
except Exception:
|
|
|
|
return default
|
2018-09-03 03:24:25 +00:00
|
|
|
if len(instances) == 1:
|
|
|
|
return instances[0].cleaned_value
|
|
|
|
else:
|
2018-11-19 04:18:52 +00:00
|
|
|
return default
|
2018-09-03 03:24:25 +00:00
|
|
|
|
2018-01-12 07:43:26 +00:00
|
|
|
@property
|
2018-01-20 14:22:09 +00:00
|
|
|
def cleaned_value(self):
|
2018-01-12 07:43:26 +00:00
|
|
|
try:
|
2018-09-03 03:24:25 +00:00
|
|
|
value = self.value
|
|
|
|
if self.encrypted:
|
|
|
|
value = signer.unsign(value)
|
|
|
|
value = json.loads(value)
|
|
|
|
return value
|
2018-01-12 07:43:26 +00:00
|
|
|
except json.JSONDecodeError:
|
|
|
|
return None
|
|
|
|
|
2018-01-20 14:22:09 +00:00
|
|
|
@cleaned_value.setter
|
|
|
|
def cleaned_value(self, item):
|
|
|
|
try:
|
|
|
|
v = json.dumps(item)
|
2018-09-03 03:24:25 +00:00
|
|
|
if self.encrypted:
|
|
|
|
v = signer.sign(v)
|
2018-01-20 14:22:09 +00:00
|
|
|
self.value = v
|
|
|
|
except json.JSONDecodeError as e:
|
|
|
|
raise ValueError("Json dump error: {}".format(str(e)))
|
|
|
|
|
2018-10-23 11:22:18 +00:00
|
|
|
@classmethod
|
|
|
|
def save_storage(cls, name, data):
|
|
|
|
obj = cls.objects.filter(name=name).first()
|
|
|
|
if not obj:
|
|
|
|
obj = cls()
|
|
|
|
obj.name = name
|
|
|
|
obj.encrypted = True
|
|
|
|
obj.cleaned_value = data
|
|
|
|
else:
|
|
|
|
value = obj.cleaned_value
|
|
|
|
value.update(data)
|
|
|
|
obj.cleaned_value = value
|
|
|
|
obj.save()
|
|
|
|
return obj
|
|
|
|
|
|
|
|
@classmethod
|
|
|
|
def delete_storage(cls, name, storage_name):
|
|
|
|
obj = cls.objects.get(name=name)
|
|
|
|
value = obj.cleaned_value
|
|
|
|
value.pop(storage_name, '')
|
|
|
|
obj.cleaned_value = value
|
|
|
|
obj.save()
|
|
|
|
return True
|
|
|
|
|
2018-01-11 12:10:27 +00:00
|
|
|
@classmethod
|
|
|
|
def refresh_all_settings(cls):
|
2018-01-22 03:38:40 +00:00
|
|
|
try:
|
|
|
|
settings_list = cls.objects.all()
|
|
|
|
for setting in settings_list:
|
|
|
|
setting.refresh_setting()
|
|
|
|
except (ProgrammingError, OperationalError):
|
|
|
|
pass
|
2018-01-11 12:10:27 +00:00
|
|
|
|
|
|
|
def refresh_setting(self):
|
2018-09-03 03:24:25 +00:00
|
|
|
setattr(settings, self.name, self.cleaned_value)
|
2016-09-03 11:05:50 +00:00
|
|
|
|
2018-01-12 07:43:26 +00:00
|
|
|
if self.name == "AUTH_LDAP":
|
2018-01-20 14:22:09 +00:00
|
|
|
if self.cleaned_value and settings.AUTH_LDAP_BACKEND not in settings.AUTHENTICATION_BACKENDS:
|
2018-03-14 11:37:36 +00:00
|
|
|
settings.AUTHENTICATION_BACKENDS.insert(0, settings.AUTH_LDAP_BACKEND)
|
2018-01-20 14:22:09 +00:00
|
|
|
elif not self.cleaned_value and settings.AUTH_LDAP_BACKEND in settings.AUTHENTICATION_BACKENDS:
|
2018-01-12 07:43:26 +00:00
|
|
|
settings.AUTHENTICATION_BACKENDS.remove(settings.AUTH_LDAP_BACKEND)
|
|
|
|
|
|
|
|
if self.name == "AUTH_LDAP_SEARCH_FILTER":
|
2018-08-07 10:11:46 +00:00
|
|
|
settings.AUTH_LDAP_USER_SEARCH_UNION = [
|
|
|
|
LDAPSearch(USER_SEARCH, ldap.SCOPE_SUBTREE, settings.AUTH_LDAP_SEARCH_FILTER)
|
|
|
|
for USER_SEARCH in str(settings.AUTH_LDAP_SEARCH_OU).split("|")
|
|
|
|
]
|
|
|
|
settings.AUTH_LDAP_USER_SEARCH = LDAPSearchUnion(*settings.AUTH_LDAP_USER_SEARCH_UNION)
|
2018-01-12 07:43:26 +00:00
|
|
|
|
2018-01-11 12:10:27 +00:00
|
|
|
class Meta:
|
|
|
|
db_table = "settings"
|
2018-04-02 05:19:31 +00:00
|
|
|
|
2018-09-03 03:24:25 +00:00
|
|
|
|
|
|
|
common_settings = Setting()
|