2018-01-11 12:10:27 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
|
|
|
from django.dispatch import receiver
|
2018-09-03 03:24:25 +00:00
|
|
|
from django.db.models.signals import post_save, pre_save
|
2018-01-12 07:43:26 +00:00
|
|
|
from django.conf import settings
|
2018-01-12 08:37:55 +00:00
|
|
|
from django.db.utils import ProgrammingError, OperationalError
|
2018-01-11 12:10:27 +00:00
|
|
|
|
2018-09-03 03:24:25 +00:00
|
|
|
from jumpserver.utils import current_request
|
2018-01-11 12:10:27 +00:00
|
|
|
from .models import Setting
|
|
|
|
from .utils import get_logger
|
2018-01-12 07:43:26 +00:00
|
|
|
from .signals import django_ready, ldap_auth_enable
|
2018-01-11 12:10:27 +00:00
|
|
|
|
|
|
|
logger = get_logger(__file__)
|
|
|
|
|
|
|
|
|
|
|
|
@receiver(post_save, sender=Setting, dispatch_uid="my_unique_identifier")
|
|
|
|
def refresh_settings_on_changed(sender, instance=None, **kwargs):
|
|
|
|
logger.debug("Receive setting item change")
|
|
|
|
logger.debug(" - refresh setting: {}".format(instance.name))
|
|
|
|
if instance:
|
|
|
|
instance.refresh_setting()
|
|
|
|
|
|
|
|
|
|
|
|
@receiver(django_ready, dispatch_uid="my_unique_identifier")
|
|
|
|
def refresh_all_settings_on_django_ready(sender, **kwargs):
|
|
|
|
logger.debug("Receive django ready signal")
|
|
|
|
logger.debug(" - fresh all settings")
|
2018-01-12 08:37:55 +00:00
|
|
|
try:
|
|
|
|
Setting.refresh_all_settings()
|
|
|
|
except (ProgrammingError, OperationalError):
|
|
|
|
pass
|
2018-01-12 07:43:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
@receiver(ldap_auth_enable, dispatch_uid="my_unique_identifier")
|
|
|
|
def ldap_auth_on_changed(sender, enabled=True, **kwargs):
|
|
|
|
if enabled:
|
|
|
|
logger.debug("Enable LDAP auth")
|
2018-05-24 04:41:48 +00:00
|
|
|
if settings.AUTH_LDAP_BACKEND not in settings.AUTHENTICATION_BACKENDS:
|
2018-01-12 07:43:26 +00:00
|
|
|
settings.AUTHENTICATION_BACKENDS.insert(0, settings.AUTH_LDAP_BACKEND)
|
|
|
|
|
|
|
|
else:
|
|
|
|
logger.debug("Disable LDAP auth")
|
|
|
|
if settings.AUTH_LDAP_BACKEND in settings.AUTHENTICATION_BACKENDS:
|
|
|
|
settings.AUTHENTICATION_BACKENDS.remove(settings.AUTH_LDAP_BACKEND)
|
|
|
|
|
2018-09-03 03:24:25 +00:00
|
|
|
|
|
|
|
@receiver(pre_save, dispatch_uid="my_unique_identifier")
|
|
|
|
def on_create_set_created_by(sender, instance=None, **kwargs):
|
|
|
|
if hasattr(instance, 'created_by') and not instance.created_by:
|
|
|
|
if current_request and current_request.user.is_authenticated:
|
|
|
|
instance.created_by = current_request.user.name
|