2018-01-11 12:10:27 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
#
|
|
|
|
import json
|
|
|
|
from django import forms
|
|
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from django.db import transaction
|
|
|
|
|
2018-11-22 04:27:27 +00:00
|
|
|
from .models import Setting, settings
|
2018-09-03 07:33:35 +00:00
|
|
|
from .fields import FormDictField, FormEncryptCharField, \
|
2018-11-19 04:18:52 +00:00
|
|
|
FormEncryptMixin
|
2018-01-11 12:10:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
class BaseForm(forms.Form):
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super().__init__(*args, **kwargs)
|
2018-01-12 07:43:26 +00:00
|
|
|
for name, field in self.fields.items():
|
2018-11-22 04:27:27 +00:00
|
|
|
value = getattr(settings, name, None)
|
2018-11-19 04:27:29 +00:00
|
|
|
if value is None: # and django_value is None:
|
2018-10-16 02:56:25 +00:00
|
|
|
continue
|
|
|
|
|
2018-11-19 04:27:29 +00:00
|
|
|
if value is not None:
|
|
|
|
if isinstance(value, dict):
|
|
|
|
value = json.dumps(value)
|
|
|
|
initial_value = value
|
2018-09-03 07:33:35 +00:00
|
|
|
else:
|
|
|
|
initial_value = ''
|
|
|
|
field.initial = initial_value
|
2018-01-11 12:10:27 +00:00
|
|
|
|
2018-01-20 14:22:09 +00:00
|
|
|
def save(self, category="default"):
|
2018-01-11 12:10:27 +00:00
|
|
|
if not self.is_bound:
|
|
|
|
raise ValueError("Form is not bound")
|
|
|
|
|
2018-09-03 03:24:25 +00:00
|
|
|
# db_settings = Setting.objects.all()
|
|
|
|
if not self.is_valid():
|
2018-01-11 12:10:27 +00:00
|
|
|
raise ValueError(self.errors)
|
|
|
|
|
2018-09-03 03:24:25 +00:00
|
|
|
with transaction.atomic():
|
|
|
|
for name, value in self.cleaned_data.items():
|
|
|
|
field = self.fields[name]
|
|
|
|
if isinstance(field.widget, forms.PasswordInput) and not value:
|
|
|
|
continue
|
2018-11-22 04:27:27 +00:00
|
|
|
if value == getattr(settings, name):
|
2018-09-03 03:24:25 +00:00
|
|
|
continue
|
|
|
|
|
|
|
|
encrypted = True if isinstance(field, FormEncryptMixin) else False
|
|
|
|
try:
|
|
|
|
setting = Setting.objects.get(name=name)
|
|
|
|
except Setting.DoesNotExist:
|
|
|
|
setting = Setting()
|
|
|
|
setting.name = name
|
|
|
|
setting.category = category
|
|
|
|
setting.encrypted = encrypted
|
|
|
|
setting.cleaned_value = value
|
|
|
|
setting.save()
|
|
|
|
|
2018-01-11 12:10:27 +00:00
|
|
|
|
2018-01-12 07:43:26 +00:00
|
|
|
class BasicSettingForm(BaseForm):
|
|
|
|
SITE_URL = forms.URLField(
|
|
|
|
label=_("Current SITE URL"),
|
2018-02-27 04:18:36 +00:00
|
|
|
help_text="eg: http://jumpserver.abc.com:8080"
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
|
|
|
USER_GUIDE_URL = forms.URLField(
|
2018-02-27 07:04:05 +00:00
|
|
|
label=_("User Guide URL"), required=False,
|
2018-01-12 07:43:26 +00:00
|
|
|
help_text=_("User first login update profile done redirect to it")
|
|
|
|
)
|
|
|
|
EMAIL_SUBJECT_PREFIX = forms.CharField(
|
|
|
|
max_length=1024, label=_("Email Subject Prefix"),
|
2018-11-23 08:24:30 +00:00
|
|
|
help_text=_("Tips: Some word will be intercept by mail provider")
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
2018-01-11 12:10:27 +00:00
|
|
|
class EmailSettingForm(BaseForm):
|
|
|
|
EMAIL_HOST = forms.CharField(
|
|
|
|
max_length=1024, label=_("SMTP host"), initial='smtp.jumpserver.org'
|
|
|
|
)
|
|
|
|
EMAIL_PORT = forms.CharField(max_length=5, label=_("SMTP port"), initial=25)
|
|
|
|
EMAIL_HOST_USER = forms.CharField(
|
|
|
|
max_length=128, label=_("SMTP user"), initial='noreply@jumpserver.org'
|
|
|
|
)
|
2018-09-03 03:24:25 +00:00
|
|
|
EMAIL_HOST_PASSWORD = FormEncryptCharField(
|
2018-01-11 12:10:27 +00:00
|
|
|
max_length=1024, label=_("SMTP password"), widget=forms.PasswordInput,
|
|
|
|
required=False, help_text=_("Some provider use token except password")
|
|
|
|
)
|
|
|
|
EMAIL_USE_SSL = forms.BooleanField(
|
|
|
|
label=_("Use SSL"), initial=False, required=False,
|
|
|
|
help_text=_("If SMTP port is 465, may be select")
|
|
|
|
)
|
|
|
|
EMAIL_USE_TLS = forms.BooleanField(
|
|
|
|
label=_("Use TLS"), initial=False, required=False,
|
|
|
|
help_text=_("If SMTP port is 587, may be select")
|
|
|
|
)
|
2018-01-12 07:43:26 +00:00
|
|
|
|
|
|
|
|
|
|
|
class LDAPSettingForm(BaseForm):
|
|
|
|
AUTH_LDAP_SERVER_URI = forms.CharField(
|
2018-11-22 04:27:27 +00:00
|
|
|
label=_("LDAP server"),
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
|
|
|
AUTH_LDAP_BIND_DN = forms.CharField(
|
2019-02-21 08:37:36 +00:00
|
|
|
required=False, label=_("Bind DN"),
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
2018-09-03 03:24:25 +00:00
|
|
|
AUTH_LDAP_BIND_PASSWORD = FormEncryptCharField(
|
2018-11-22 04:27:27 +00:00
|
|
|
label=_("Password"),
|
2018-01-12 07:43:26 +00:00
|
|
|
widget=forms.PasswordInput, required=False
|
|
|
|
)
|
|
|
|
AUTH_LDAP_SEARCH_OU = forms.CharField(
|
2018-11-22 04:27:27 +00:00
|
|
|
label=_("User OU"),
|
2018-08-07 10:11:46 +00:00
|
|
|
help_text=_("Use | split User OUs")
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
|
|
|
AUTH_LDAP_SEARCH_FILTER = forms.CharField(
|
2018-11-22 04:27:27 +00:00
|
|
|
label=_("User search filter"),
|
2018-03-14 11:33:48 +00:00
|
|
|
help_text=_("Choice may be (cn|uid|sAMAccountName)=%(user)s)")
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
2018-09-03 07:33:35 +00:00
|
|
|
AUTH_LDAP_USER_ATTR_MAP = FormDictField(
|
2018-01-12 07:43:26 +00:00
|
|
|
label=_("User attr map"),
|
2018-02-26 07:06:00 +00:00
|
|
|
help_text=_(
|
2018-09-03 07:33:35 +00:00
|
|
|
"User attr map present how to map LDAP user attr to jumpserver, "
|
|
|
|
"username,name,email is jumpserver attr"
|
2018-11-22 04:27:27 +00:00
|
|
|
),
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
|
|
|
# AUTH_LDAP_GROUP_SEARCH_OU = CONFIG.AUTH_LDAP_GROUP_SEARCH_OU
|
|
|
|
# AUTH_LDAP_GROUP_SEARCH_FILTER = CONFIG.AUTH_LDAP_GROUP_SEARCH_FILTER
|
|
|
|
AUTH_LDAP_START_TLS = forms.BooleanField(
|
2018-11-22 04:27:27 +00:00
|
|
|
label=_("Use SSL"), required=False
|
2018-01-12 07:43:26 +00:00
|
|
|
)
|
2018-11-22 04:27:27 +00:00
|
|
|
AUTH_LDAP = forms.BooleanField(label=_("Enable LDAP auth"), required=False)
|
2018-01-20 14:22:09 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TerminalSettingForm(BaseForm):
|
|
|
|
SORT_BY_CHOICES = (
|
|
|
|
('hostname', _('Hostname')),
|
|
|
|
('ip', _('IP')),
|
|
|
|
)
|
2018-12-17 03:18:55 +00:00
|
|
|
PAGE_SIZE_CHOICES = (
|
|
|
|
('all', _('All')),
|
|
|
|
('auto', _('Auto')),
|
|
|
|
(10, 10),
|
|
|
|
(15, 15),
|
|
|
|
(25, 25),
|
|
|
|
(50, 50),
|
|
|
|
)
|
2018-01-20 14:22:09 +00:00
|
|
|
TERMINAL_PASSWORD_AUTH = forms.BooleanField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("Password auth")
|
2018-01-20 14:22:09 +00:00
|
|
|
)
|
|
|
|
TERMINAL_PUBLIC_KEY_AUTH = forms.BooleanField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("Public key auth")
|
2018-01-20 14:22:09 +00:00
|
|
|
)
|
2018-10-23 11:22:18 +00:00
|
|
|
TERMINAL_HEARTBEAT_INTERVAL = forms.IntegerField(
|
2018-12-25 01:58:01 +00:00
|
|
|
min_value=5, label=_("Heartbeat interval"),
|
|
|
|
help_text=_("Units: seconds")
|
2018-01-20 14:22:09 +00:00
|
|
|
)
|
2018-10-23 11:22:18 +00:00
|
|
|
TERMINAL_ASSET_LIST_SORT_BY = forms.ChoiceField(
|
2018-12-25 01:58:01 +00:00
|
|
|
choices=SORT_BY_CHOICES, label=_("List sort by")
|
2018-02-26 07:06:00 +00:00
|
|
|
)
|
2018-12-17 03:18:55 +00:00
|
|
|
TERMINAL_ASSET_LIST_PAGE_SIZE = forms.ChoiceField(
|
2018-12-25 01:58:01 +00:00
|
|
|
choices=PAGE_SIZE_CHOICES, label=_("List page size"),
|
2018-12-17 03:18:55 +00:00
|
|
|
)
|
2018-12-18 03:29:21 +00:00
|
|
|
TERMINAL_SESSION_KEEP_DURATION = forms.IntegerField(
|
2018-12-25 01:58:01 +00:00
|
|
|
min_value=1, label=_("Session keep duration"),
|
2018-12-18 03:29:21 +00:00
|
|
|
help_text=_("Units: days, Session, record, command will be delete "
|
|
|
|
"if more than duration, only in database")
|
|
|
|
)
|
2019-02-20 11:00:01 +00:00
|
|
|
TERMINAL_TELNET_REGEX = forms.CharField(
|
|
|
|
required=False, label=_("Telnet login regex"),
|
|
|
|
help_text=_("ex: Last\s*login|success|成功")
|
|
|
|
)
|
2018-10-23 11:22:18 +00:00
|
|
|
|
|
|
|
|
|
|
|
class TerminalCommandStorage(BaseForm):
|
|
|
|
pass
|
2018-02-26 07:06:00 +00:00
|
|
|
|
2018-06-05 09:26:31 +00:00
|
|
|
|
|
|
|
class SecuritySettingForm(BaseForm):
|
2018-07-05 08:23:33 +00:00
|
|
|
# MFA global setting
|
2018-06-05 09:26:31 +00:00
|
|
|
SECURITY_MFA_AUTH = forms.BooleanField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("MFA Secondary certification"),
|
2018-06-05 09:26:31 +00:00
|
|
|
help_text=_(
|
|
|
|
'After opening, the user login must use MFA secondary '
|
|
|
|
'authentication (valid for all users, including administrators)'
|
|
|
|
)
|
|
|
|
)
|
2018-07-05 08:23:33 +00:00
|
|
|
# limit login count
|
|
|
|
SECURITY_LOGIN_LIMIT_COUNT = forms.IntegerField(
|
2018-12-25 01:58:01 +00:00
|
|
|
min_value=3, label=_("Limit the number of login failures")
|
2018-07-05 08:23:33 +00:00
|
|
|
)
|
|
|
|
# limit login time
|
|
|
|
SECURITY_LOGIN_LIMIT_TIME = forms.IntegerField(
|
2018-12-25 01:58:01 +00:00
|
|
|
min_value=5, label=_("No logon interval"),
|
2018-07-05 08:23:33 +00:00
|
|
|
help_text=_(
|
2018-11-22 10:02:12 +00:00
|
|
|
"Tip: (unit/minute) if the user has failed to log in for a limited "
|
2018-07-05 08:23:33 +00:00
|
|
|
"number of times, no login is allowed during this time interval."
|
|
|
|
)
|
|
|
|
)
|
2018-11-22 10:02:12 +00:00
|
|
|
# ssh max idle time
|
2018-09-03 03:24:25 +00:00
|
|
|
SECURITY_MAX_IDLE_TIME = forms.IntegerField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("Connection max idle time"),
|
2018-09-03 03:24:25 +00:00
|
|
|
help_text=_(
|
|
|
|
'If idle time more than it, disconnect connection(only ssh now) '
|
|
|
|
'Unit: minute'
|
|
|
|
),
|
|
|
|
)
|
2018-11-22 10:02:12 +00:00
|
|
|
# password expiration time
|
|
|
|
SECURITY_PASSWORD_EXPIRATION_TIME = forms.IntegerField(
|
2018-12-25 01:58:01 +00:00
|
|
|
label=_("Password expiration time"),
|
|
|
|
min_value=1, max_value=99999,
|
2018-11-22 10:02:12 +00:00
|
|
|
help_text=_(
|
2018-11-23 09:00:35 +00:00
|
|
|
"Tip: (unit: day) "
|
2018-11-22 10:02:12 +00:00
|
|
|
"If the user does not update the password during the time, "
|
|
|
|
"the user password will expire failure;"
|
|
|
|
"The password expiration reminder mail will be automatic sent to the user "
|
|
|
|
"by system within 5 days (daily) before the password expires"
|
|
|
|
)
|
|
|
|
)
|
2018-07-05 08:23:33 +00:00
|
|
|
# min length
|
2018-06-05 09:26:31 +00:00
|
|
|
SECURITY_PASSWORD_MIN_LENGTH = forms.IntegerField(
|
2018-12-25 01:58:01 +00:00
|
|
|
min_value=6, label=_("Password minimum length"),
|
2018-06-05 09:26:31 +00:00
|
|
|
)
|
2018-07-05 08:23:33 +00:00
|
|
|
# upper case
|
2018-06-05 09:26:31 +00:00
|
|
|
SECURITY_PASSWORD_UPPER_CASE = forms.BooleanField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("Must contain capital letters"),
|
2018-06-05 09:26:31 +00:00
|
|
|
help_text=_(
|
|
|
|
'After opening, the user password changes '
|
|
|
|
'and resets must contain uppercase letters')
|
|
|
|
)
|
2018-07-05 08:23:33 +00:00
|
|
|
# lower case
|
2018-06-05 09:26:31 +00:00
|
|
|
SECURITY_PASSWORD_LOWER_CASE = forms.BooleanField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("Must contain lowercase letters"),
|
2018-06-05 09:26:31 +00:00
|
|
|
help_text=_('After opening, the user password changes '
|
|
|
|
'and resets must contain lowercase letters')
|
|
|
|
)
|
2018-07-05 08:23:33 +00:00
|
|
|
# number
|
2018-06-05 09:26:31 +00:00
|
|
|
SECURITY_PASSWORD_NUMBER = forms.BooleanField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("Must contain numeric characters"),
|
2018-06-05 09:26:31 +00:00
|
|
|
help_text=_('After opening, the user password changes '
|
|
|
|
'and resets must contain numeric characters')
|
|
|
|
)
|
2018-07-05 08:23:33 +00:00
|
|
|
# special char
|
2018-09-03 03:24:25 +00:00
|
|
|
SECURITY_PASSWORD_SPECIAL_CHAR = forms.BooleanField(
|
2018-12-25 01:58:01 +00:00
|
|
|
required=False, label=_("Must contain special characters"),
|
2018-06-05 09:26:31 +00:00
|
|
|
help_text=_('After opening, the user password changes '
|
|
|
|
'and resets must contain special characters')
|
|
|
|
)
|
2018-09-03 03:24:25 +00:00
|
|
|
|