mirror of https://github.com/jumpserver/jumpserver
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
180 lines
7.2 KiB
180 lines
7.2 KiB
from django.conf import settings |
|
from django.utils.translation import gettext_lazy as _ |
|
from rest_framework import serializers |
|
|
|
from accounts.models import Account |
|
from assets.models import Platform |
|
from assets.serializers import HostSerializer |
|
from common.const.choices import Status |
|
from common.serializers.fields import LabeledChoiceField |
|
from common.validators import ProjectUniqueValidator |
|
from .applet import AppletSerializer |
|
from .. import const |
|
from ..models import AppletHost, AppletHostDeployment |
|
|
|
__all__ = [ |
|
'AppletHostSerializer', 'AppletHostDeploymentSerializer', |
|
'AppletHostAccountSerializer', 'AppletHostAppletReportSerializer', |
|
'AppletHostStartupSerializer', 'AppletSetupSerializer' |
|
] |
|
|
|
|
|
class DeployOptionsSerializer(serializers.Serializer): |
|
LICENSE_MODE_CHOICES = ( |
|
(2, _('Per Device (Device number limit)')), |
|
(4, _('Per User (User number limit)')), |
|
) |
|
|
|
# 单用户单会话, |
|
# 默认值为1,表示启用状态(组策略默认值),此时单用户只能有一个会话连接 |
|
# 如果改为 0 ,表示禁用状态,此时可以单用户多会话连接 |
|
SESSION_PER_USER = ( |
|
(0, _("Disabled")), |
|
(1, _("Enabled")), |
|
) |
|
|
|
CORE_HOST = serializers.CharField( |
|
default=settings.SITE_URL, label=_('Core API'), max_length=1024, |
|
help_text=_(""" |
|
Tips: The application release machine communicates with the Core service. |
|
If the release machine and the Core service are on the same network segment, |
|
it is recommended to fill in the intranet address, otherwise fill in the current site URL |
|
<br> |
|
eg: https://172.16.10.110 or https://dev.jumpserver.com |
|
""") |
|
) |
|
IGNORE_VERIFY_CERTS = serializers.BooleanField(default=True, label=_("Ignore Certificate Verification")) |
|
RDS_Licensing = serializers.BooleanField( |
|
default=False, label=_("Existing RDS license"), |
|
help_text=_( |
|
'If not exist, the RDS will be in trial mode, and the trial period is 120 days. <a ' |
|
'href="https://learn.microsoft.com/en-us/windows-server/remote/remote-desktop-services/rds-client-access' |
|
'-license">Detail</a>' |
|
) |
|
) |
|
RDS_LicenseServer = serializers.CharField(default='127.0.0.1', label=_('RDS License Server'), max_length=1024) |
|
RDS_LicensingMode = serializers.ChoiceField( |
|
choices=LICENSE_MODE_CHOICES, default=2, label=_('RDS Licensing Mode'), |
|
) |
|
RDS_fSingleSessionPerUser = serializers.ChoiceField( |
|
choices=SESSION_PER_USER, default=1, label=_("RDS Single Session Per User"), |
|
help_text=_('Tips: A RDS user can have only one session at a time. If set, when next login connected, ' |
|
'previous session will be disconnected.') |
|
) |
|
RDS_MaxDisconnectionTime = serializers.IntegerField( |
|
default=60000, label=_("RDS Max Disconnection Time (ms)"), |
|
help_text=_( |
|
'Tips: Set the maximum duration for keeping a disconnected session active on the server (log off the ' |
|
'session after 60000 milliseconds).' |
|
) |
|
) |
|
RDS_RemoteAppLogoffTimeLimit = serializers.IntegerField( |
|
default=0, label=_("RDS Remote App Logoff Time Limit (ms)"), |
|
help_text=_( |
|
'Tips: Set the logoff time for RemoteApp sessions after closing all RemoteApp programs (0 milliseconds, ' |
|
'log off the session immediately).' |
|
) |
|
) |
|
|
|
|
|
class AppletHostSerializer(HostSerializer): |
|
deploy_options = DeployOptionsSerializer(required=False, label=_("Deploy options")) |
|
load = LabeledChoiceField( |
|
read_only=True, label=_('Load status'), choices=const.ComponentLoad.choices, |
|
) |
|
|
|
class Meta(HostSerializer.Meta): |
|
model = AppletHost |
|
fields = HostSerializer.Meta.fields + [ |
|
'auto_create_accounts', 'accounts_create_amount', |
|
'load', 'date_synced', 'deploy_options', 'using_same_account', |
|
] |
|
extra_kwargs = { |
|
**HostSerializer.Meta.extra_kwargs, |
|
'date_synced': {'read_only': True}, |
|
'auto_create_accounts': { |
|
'help_text': _( |
|
'These accounts are used to connect to the published application, ' |
|
'the account is now divided into two types, one is dedicated to each account, ' |
|
'each user has a private account, the other is public, ' |
|
'when the application does not support multiple open and the special has been used, ' |
|
'the public account will be used to connect' |
|
) |
|
}, |
|
'accounts_create_amount': {'help_text': _('The number of public accounts created automatically')}, |
|
'using_same_account': { |
|
'help_text': _( |
|
'Connect to the host using the same account first. For security reasons, please set the ' |
|
'configuration item CACHE_LOGIN_PASSWORD_ENABLED=true and restart the service to enable it.' |
|
) |
|
} |
|
} |
|
|
|
def __init__(self, *args, data=None, **kwargs): |
|
if data: |
|
self.set_initial_data(data) |
|
kwargs['data'] = data |
|
super().__init__(*args, **kwargs) |
|
|
|
@staticmethod |
|
def set_initial_data(data): |
|
platform = Platform.objects.get(name='RemoteAppHost') |
|
data.update({ |
|
'platform': platform.id, |
|
'nodes_display': [ |
|
'RemoteAppHosts' |
|
] |
|
}) |
|
|
|
def get_validators(self): |
|
validators = super().get_validators() |
|
# 不知道为啥没有继承过来 |
|
uniq_validator = ProjectUniqueValidator( |
|
queryset=AppletHost.objects.all(), |
|
fields=('org_id', 'name') |
|
) |
|
validators.append(uniq_validator) |
|
return validators |
|
|
|
|
|
class HostAppletSerializer(AppletSerializer): |
|
publication = serializers.SerializerMethodField() |
|
|
|
class Meta(AppletSerializer.Meta): |
|
fields = AppletSerializer.Meta.fields + ['publication'] |
|
|
|
|
|
class AppletHostDeploymentSerializer(serializers.ModelSerializer): |
|
status = LabeledChoiceField(choices=Status.choices, label=_('Status'), default=Status.pending) |
|
install_applets = serializers.BooleanField(default=True, label=_('Install applets'), write_only=True) |
|
|
|
class Meta: |
|
model = AppletHostDeployment |
|
fields_mini = ['id', 'host', 'status', 'task'] |
|
read_only_fields = [ |
|
'status', 'date_created', 'date_updated', |
|
'date_start', 'date_finished' |
|
] |
|
write_only_fields = ['install_applets', ] |
|
fields = fields_mini + ['comment'] + read_only_fields + write_only_fields |
|
|
|
|
|
class AppletHostAccountSerializer(serializers.ModelSerializer): |
|
class Meta: |
|
model = Account |
|
fields = ['id', 'username', 'secret', 'is_active', 'date_updated'] |
|
|
|
|
|
class AppletHostAppletReportSerializer(serializers.Serializer): |
|
id = serializers.UUIDField(read_only=True) |
|
name = serializers.CharField() |
|
version = serializers.CharField() |
|
|
|
|
|
class AppletHostStartupSerializer(serializers.Serializer): |
|
pass |
|
|
|
|
|
class AppletSetupSerializer(serializers.Serializer): |
|
hosts = serializers.ListField(child=serializers.UUIDField(label=_('Host ID')), label=_('Hosts')) |
|
applet_id = serializers.UUIDField(label=_('Applet ID'))
|
|
|