mirror of
https://github.com/jumpserver/jumpserver.git
synced 2025-09-06 01:40:52 +00:00
Asset meta (#3539)
- 更改了资产表单,影响 - 资产创建和更新 - 增加了资产平台数据库,影响 - 平台创建更新和删除 - 更改了资产的platform字段,又一个字符字段,改为一个外键,影响 - 资产创建和更新 - 资产连接 [windows,linux] - 测试连接等ansible任务 - 自动化云导入 - 更改了资产的序列化器,影响 - 资产创建更新列表 - 统一了树列表基础模板,影响 - 资产列表页,权限列表页,vault页,资产收集页 - 统一了导入导出组件,影响 - 资产导入导出 - 用户导入导出 - 用户组导入导出 - 系统用户导入导出 - 管理用户导入导出 - vault导出导出 - 收集用户列表导入导出 - 修改用户更新密码信号,影响 - 修改用户密码产生的改密日志 - 新增Model instance序列化工具函数,影响 - 操作日志生成 - 修改api mixin,新增 serializer_classes字段,serializer_classes = {"default": "", "display": "", "list": .., "other_action": ""}, 根据用户请求的方式返回不同的serializer_class,影响 - 用户的viewset - 资产权限的viewset - 统一系统配置中的tab切换 - 统一没有nav的页面,影响 - 重置密码 - 忘记密码 - 重置中设置密码 - 独立的message页面 - 修改用户组列表页,不再返还用户组下的用户,仅有数量 - 组织的一些方法变为layzproperty,避免重复计算 - 修改用户组详情页,影响 - 用户组增加删除用户
This commit is contained in:
152
apps/users/forms/profile.py
Normal file
152
apps/users/forms/profile.py
Normal file
@@ -0,0 +1,152 @@
|
||||
# -*- coding: utf-8 -*-
|
||||
#
|
||||
from django import forms
|
||||
from django.utils.translation import gettext_lazy as _
|
||||
from captcha.fields import CaptchaField
|
||||
|
||||
from common.utils import validate_ssh_public_key
|
||||
from ..models import User
|
||||
|
||||
|
||||
__all__ = [
|
||||
'UserProfileForm', 'UserMFAForm', 'UserFirstLoginFinishForm',
|
||||
'UserPasswordForm', 'UserPublicKeyForm', 'FileForm',
|
||||
'UserTokenResetPasswordForm', 'UserForgotPasswordForm',
|
||||
]
|
||||
|
||||
|
||||
class UserProfileForm(forms.ModelForm):
|
||||
username = forms.CharField(disabled=True, label=_("Username"))
|
||||
name = forms.CharField(disabled=True, label=_("Name"))
|
||||
email = forms.CharField(disabled=True)
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
fields = [
|
||||
'username', 'name', 'email',
|
||||
'wechat', 'phone',
|
||||
]
|
||||
|
||||
|
||||
UserProfileForm.verbose_name = _("Profile")
|
||||
|
||||
|
||||
class UserMFAForm(forms.ModelForm):
|
||||
|
||||
mfa_description = _(
|
||||
'When enabled, '
|
||||
'you will enter the MFA binding process the next time you log in. '
|
||||
'you can also directly bind in '
|
||||
'"personal information -> quick modification -> change MFA Settings"!')
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
fields = ['mfa_level']
|
||||
widgets = {'mfa_level': forms.RadioSelect()}
|
||||
help_texts = {
|
||||
'mfa_level': _('* Enable MFA authentication '
|
||||
'to make the account more secure.'),
|
||||
}
|
||||
|
||||
|
||||
UserMFAForm.verbose_name = _("MFA")
|
||||
|
||||
|
||||
class UserFirstLoginFinishForm(forms.Form):
|
||||
finish_description = _(
|
||||
'In order to protect you and your company, '
|
||||
'please keep your account, '
|
||||
'password and key sensitive information properly. '
|
||||
'(for example: setting complex password, enabling MFA authentication)'
|
||||
)
|
||||
|
||||
|
||||
UserFirstLoginFinishForm.verbose_name = _("Finish")
|
||||
|
||||
|
||||
class UserTokenResetPasswordForm(forms.Form):
|
||||
new_password = forms.CharField(
|
||||
min_length=5, max_length=128,
|
||||
widget=forms.PasswordInput,
|
||||
label=_("New password")
|
||||
)
|
||||
confirm_password = forms.CharField(
|
||||
min_length=5, max_length=128,
|
||||
widget=forms.PasswordInput,
|
||||
label=_("Confirm password")
|
||||
)
|
||||
|
||||
def clean_confirm_password(self):
|
||||
new_password = self.cleaned_data['new_password']
|
||||
confirm_password = self.cleaned_data['confirm_password']
|
||||
|
||||
if new_password != confirm_password:
|
||||
raise forms.ValidationError(_('Password does not match'))
|
||||
return confirm_password
|
||||
|
||||
|
||||
class UserForgotPasswordForm(forms.Form):
|
||||
email = forms.EmailField(label=_("Email"))
|
||||
captcha = CaptchaField(label=_("Captcha"))
|
||||
|
||||
|
||||
class UserPasswordForm(UserTokenResetPasswordForm):
|
||||
old_password = forms.CharField(
|
||||
max_length=128, widget=forms.PasswordInput,
|
||||
label=_("Old password")
|
||||
)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
self.instance = kwargs.pop('instance')
|
||||
super().__init__(*args, **kwargs)
|
||||
|
||||
def clean_old_password(self):
|
||||
old_password = self.cleaned_data['old_password']
|
||||
if not self.instance.check_password(old_password):
|
||||
raise forms.ValidationError(_('Old password error'))
|
||||
return old_password
|
||||
|
||||
def save(self):
|
||||
password = self.cleaned_data['new_password']
|
||||
self.instance.reset_password(new_password=password)
|
||||
return self.instance
|
||||
|
||||
|
||||
class UserPublicKeyForm(forms.Form):
|
||||
pubkey_description = _('Automatically configure and download the SSH key')
|
||||
public_key = forms.CharField(
|
||||
label=_('ssh public key'), max_length=5000, required=False,
|
||||
widget=forms.Textarea(attrs={'placeholder': _('ssh-rsa AAAA...')}),
|
||||
help_text=_('Paste your id_rsa.pub here.')
|
||||
)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
if 'instance' in kwargs:
|
||||
self.instance = kwargs.pop('instance')
|
||||
else:
|
||||
self.instance = None
|
||||
super().__init__(*args, **kwargs)
|
||||
|
||||
def clean_public_key(self):
|
||||
public_key = self.cleaned_data['public_key']
|
||||
if self.instance.public_key and public_key == self.instance.public_key:
|
||||
msg = _('Public key should not be the same as your old one.')
|
||||
raise forms.ValidationError(msg)
|
||||
|
||||
if public_key and not validate_ssh_public_key(public_key):
|
||||
raise forms.ValidationError(_('Not a valid ssh public key'))
|
||||
return public_key
|
||||
|
||||
def save(self):
|
||||
public_key = self.cleaned_data['public_key']
|
||||
if public_key:
|
||||
self.instance.public_key = public_key
|
||||
self.instance.save()
|
||||
return self.instance
|
||||
|
||||
|
||||
UserPublicKeyForm.verbose_name = _("Public key")
|
||||
|
||||
|
||||
class FileForm(forms.Form):
|
||||
file = forms.FileField()
|
Reference in New Issue
Block a user