mirror of https://github.com/jumpserver/jumpserver
Vnc (#2226)
* [Update] 优化授权协议, 支持vnc * [Update] 添加协议vnc * [Update] 修改系统用户添加 * [Update] 修改vnc信息pull/2230/head
parent
fe7c3c29ad
commit
332be54b46
|
@ -36,14 +36,12 @@ class DomainForm(forms.ModelForm):
|
||||||
|
|
||||||
|
|
||||||
class GatewayForm(PasswordAndKeyAuthForm, OrgModelForm):
|
class GatewayForm(PasswordAndKeyAuthForm, OrgModelForm):
|
||||||
protocol = forms.ChoiceField(
|
|
||||||
choices=[Gateway.PROTOCOL_CHOICES[0]],
|
|
||||||
)
|
|
||||||
|
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super().__init__(*args, **kwargs)
|
super().__init__(*args, **kwargs)
|
||||||
password_field = self.fields.get('password')
|
password_field = self.fields.get('password')
|
||||||
password_field.help_text = _('Password should not contain special characters')
|
password_field.help_text = _('Password should not contain special characters')
|
||||||
|
protocol_field = self.fields.get('protocol')
|
||||||
|
protocol_field.choices = [Gateway.PROTOCOL_CHOICES[0]]
|
||||||
|
|
||||||
def save(self, commit=True):
|
def save(self, commit=True):
|
||||||
# Because we define custom field, so we need rewrite :method: `save`
|
# Because we define custom field, so we need rewrite :method: `save`
|
||||||
|
|
|
@ -100,7 +100,9 @@ class SystemUserForm(OrgModelForm, PasswordAndKeyAuthForm):
|
||||||
private_key, public_key = super().gen_keys()
|
private_key, public_key = super().gen_keys()
|
||||||
|
|
||||||
if login_mode == SystemUser.LOGIN_MANUAL or \
|
if login_mode == SystemUser.LOGIN_MANUAL or \
|
||||||
protocol in [SystemUser.PROTOCOL_RDP, SystemUser.PROTOCOL_TELNET]:
|
protocol in [SystemUser.PROTOCOL_RDP,
|
||||||
|
SystemUser.PROTOCOL_TELNET,
|
||||||
|
SystemUser.PROTOCOL_VNC]:
|
||||||
system_user.auto_push = 0
|
system_user.auto_push = 0
|
||||||
auto_generate_key = False
|
auto_generate_key = False
|
||||||
system_user.save()
|
system_user.save()
|
||||||
|
@ -120,17 +122,18 @@ class SystemUserForm(OrgModelForm, PasswordAndKeyAuthForm):
|
||||||
if not self.instance and not auto_generate:
|
if not self.instance and not auto_generate:
|
||||||
super().validate_password_key()
|
super().validate_password_key()
|
||||||
|
|
||||||
def is_valid(self):
|
def clean_username(self):
|
||||||
validated = super().is_valid()
|
username = self.data.get('username')
|
||||||
username = self.cleaned_data.get('username')
|
login_mode = self.data.get('login_mode')
|
||||||
login_mode = self.cleaned_data.get('login_mode')
|
protocol = self.data.get('protocol')
|
||||||
if login_mode == SystemUser.LOGIN_AUTO and not username:
|
|
||||||
self.add_error(
|
if username:
|
||||||
"username", _('* Automatic login mode,'
|
return username
|
||||||
' must fill in the username.')
|
if login_mode == SystemUser.LOGIN_AUTO and \
|
||||||
)
|
protocol != SystemUser.PROTOCOL_VNC:
|
||||||
return False
|
msg = _('* Automatic login mode must fill in the username.')
|
||||||
return validated
|
raise forms.ValidationError(msg)
|
||||||
|
return username
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = SystemUser
|
model = SystemUser
|
||||||
|
@ -148,7 +151,6 @@ class SystemUserForm(OrgModelForm, PasswordAndKeyAuthForm):
|
||||||
}
|
}
|
||||||
help_texts = {
|
help_texts = {
|
||||||
'name': '* required',
|
'name': '* required',
|
||||||
'username': '* required',
|
|
||||||
'auto_push': _('Auto push system user to asset'),
|
'auto_push': _('Auto push system user to asset'),
|
||||||
'priority': _('1-100, High level will be using login asset as default, '
|
'priority': _('1-100, High level will be using login asset as default, '
|
||||||
'if user was granted more than 2 system user'),
|
'if user was granted more than 2 system user'),
|
||||||
|
|
|
@ -40,15 +40,15 @@ class Domain(OrgModelMixin):
|
||||||
|
|
||||||
|
|
||||||
class Gateway(AssetUser):
|
class Gateway(AssetUser):
|
||||||
SSH_PROTOCOL = 'ssh'
|
PROTOCOL_SSH = 'ssh'
|
||||||
RDP_PROTOCOL = 'rdp'
|
PROTOCOL_RDP = 'rdp'
|
||||||
PROTOCOL_CHOICES = (
|
PROTOCOL_CHOICES = (
|
||||||
(SSH_PROTOCOL, 'ssh'),
|
(PROTOCOL_SSH, 'ssh'),
|
||||||
(RDP_PROTOCOL, 'rdp'),
|
(PROTOCOL_RDP, 'rdp'),
|
||||||
)
|
)
|
||||||
ip = models.GenericIPAddressField(max_length=32, verbose_name=_('IP'), db_index=True)
|
ip = models.GenericIPAddressField(max_length=32, verbose_name=_('IP'), db_index=True)
|
||||||
port = models.IntegerField(default=22, verbose_name=_('Port'))
|
port = models.IntegerField(default=22, verbose_name=_('Port'))
|
||||||
protocol = models.CharField(choices=PROTOCOL_CHOICES, max_length=16, default=SSH_PROTOCOL, verbose_name=_("Protocol"))
|
protocol = models.CharField(choices=PROTOCOL_CHOICES, max_length=16, default=PROTOCOL_SSH, verbose_name=_("Protocol"))
|
||||||
domain = models.ForeignKey(Domain, on_delete=models.CASCADE, verbose_name=_("Domain"))
|
domain = models.ForeignKey(Domain, on_delete=models.CASCADE, verbose_name=_("Domain"))
|
||||||
comment = models.CharField(max_length=128, blank=True, null=True, verbose_name=_("Comment"))
|
comment = models.CharField(max_length=128, blank=True, null=True, verbose_name=_("Comment"))
|
||||||
is_active = models.BooleanField(default=True, verbose_name=_("Is active"))
|
is_active = models.BooleanField(default=True, verbose_name=_("Is active"))
|
||||||
|
|
|
@ -29,6 +29,7 @@ class Node(OrgModelMixin):
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
verbose_name = _("Node")
|
verbose_name = _("Node")
|
||||||
|
ordering = ('key',)
|
||||||
|
|
||||||
def __str__(self):
|
def __str__(self):
|
||||||
return self.full_value
|
return self.full_value
|
||||||
|
|
|
@ -73,7 +73,7 @@ function initTable2() {
|
||||||
return asset_table2
|
return asset_table2
|
||||||
}
|
}
|
||||||
|
|
||||||
function onSelected2(event, treeNode) {
|
function onNodeSelected2(event, treeNode) {
|
||||||
var url = asset_table2.ajax.url();
|
var url = asset_table2.ajax.url();
|
||||||
url = setUrlParam(url, "node_id", treeNode.meta.node.id);
|
url = setUrlParam(url, "node_id", treeNode.meta.node.id);
|
||||||
asset_table2.ajax.url(url);
|
asset_table2.ajax.url(url);
|
||||||
|
@ -100,7 +100,7 @@ function initTree2() {
|
||||||
type: 'get'
|
type: 'get'
|
||||||
},
|
},
|
||||||
callback: {
|
callback: {
|
||||||
onSelected: onSelected2
|
onSelected: onNodeSelected2
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
zTree2 = $.fn.zTree.init($("#assetTree2"), setting);
|
zTree2 = $.fn.zTree.init($("#assetTree2"), setting);
|
||||||
|
|
|
@ -103,15 +103,17 @@ var need_change_field_login_mode = [
|
||||||
];
|
];
|
||||||
|
|
||||||
function protocolChange() {
|
function protocolChange() {
|
||||||
if ($(protocol_id + " option:selected").text() === 'rdp') {
|
var protocol = $(protocol_id + " option:selected").text();
|
||||||
|
if (protocol === 'rdp' || protocol === 'vnc') {
|
||||||
$('.auth-fields').removeClass('hidden');
|
$('.auth-fields').removeClass('hidden');
|
||||||
$('#command-filter-block').addClass('hidden');
|
$('#command-filter-block').addClass('hidden');
|
||||||
$.each(need_change_field, function (index, value) {
|
$.each(need_change_field, function (index, value) {
|
||||||
$(value).closest('.form-group').addClass('hidden')
|
$(value).closest('.form-group').addClass('hidden')
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
else if ($(protocol_id + " option:selected").text() === 'telnet (beta)') {
|
else if (protocol === 'telnet (beta)') {
|
||||||
$('.auth-fields').removeClass('hidden');
|
$('.auth-fields').removeClass('hidden');
|
||||||
|
$('#command-filter-block').removeClass('hidden');
|
||||||
$.each(need_change_field, function (index, value) {
|
$.each(need_change_field, function (index, value) {
|
||||||
$(value).closest('.form-group').addClass('hidden')
|
$(value).closest('.form-group').addClass('hidden')
|
||||||
});
|
});
|
||||||
|
@ -123,6 +125,7 @@ function protocolChange() {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
authFieldsDisplay();
|
authFieldsDisplay();
|
||||||
|
$('#command-filter-block').removeClass('hidden');
|
||||||
$.each(need_change_field, function (index, value) {
|
$.each(need_change_field, function (index, value) {
|
||||||
$(value).closest('.form-group').removeClass('hidden')
|
$(value).closest('.form-group').removeClass('hidden')
|
||||||
});
|
});
|
||||||
|
|
Binary file not shown.
File diff suppressed because it is too large
Load Diff
|
@ -12,8 +12,6 @@ from .models import AssetPermission
|
||||||
class AssetPermissionForm(OrgModelForm):
|
class AssetPermissionForm(OrgModelForm):
|
||||||
def __init__(self, *args, **kwargs):
|
def __init__(self, *args, **kwargs):
|
||||||
super().__init__(*args, **kwargs)
|
super().__init__(*args, **kwargs)
|
||||||
if 'initial' not in kwargs:
|
|
||||||
return
|
|
||||||
users_field = self.fields.get('users')
|
users_field = self.fields.get('users')
|
||||||
if hasattr(users_field, 'queryset'):
|
if hasattr(users_field, 'queryset'):
|
||||||
users_field.queryset = current_org.get_org_users()
|
users_field.queryset = current_org.get_org_users()
|
||||||
|
|
Loading…
Reference in New Issue