mirror of https://github.com/jumpserver/jumpserver
141 lines
4.8 KiB
Python
141 lines
4.8 KiB
Python
from rest_framework import serializers
|
|
from django.utils.translation import ugettext_lazy as _
|
|
|
|
from common.drf.serializers import BulkModelSerializer, AdaptedBulkListSerializer
|
|
from common.utils import is_uuid
|
|
from users.serializers import ServiceAccountSerializer
|
|
from common.utils import get_request_ip
|
|
from .. import const
|
|
|
|
from ..models import (
|
|
Terminal, Status, Task, CommandStorage, ReplayStorage
|
|
)
|
|
|
|
|
|
class StatusSerializer(serializers.ModelSerializer):
|
|
sessions = serializers.ListSerializer(
|
|
child=serializers.CharField(max_length=36), write_only=True
|
|
)
|
|
|
|
class Meta:
|
|
fields_mini = ['id']
|
|
fields_write_only = ['sessions', ]
|
|
fields_small = fields_mini + fields_write_only + [
|
|
'cpu_load', 'memory_used', 'disk_used',
|
|
'session_online',
|
|
'date_created'
|
|
]
|
|
fields_fk = ['terminal']
|
|
fields = fields_small + fields_fk
|
|
extra_kwargs = {
|
|
"cpu_load": {'default': 0},
|
|
"memory_used": {'default': 0},
|
|
"disk_used": {'default': 0},
|
|
}
|
|
model = Status
|
|
|
|
|
|
class TerminalSerializer(BulkModelSerializer):
|
|
session_online = serializers.ReadOnlyField(source='get_online_session_count')
|
|
is_alive = serializers.BooleanField(read_only=True)
|
|
is_active = serializers.BooleanField(read_only=True, label='Is active')
|
|
status = serializers.ChoiceField(
|
|
read_only=True, choices=const.ComponentStatusChoices.choices,
|
|
source='latest_status', label=_('Load status')
|
|
)
|
|
status_display = serializers.CharField(read_only=True, source='latest_status_display')
|
|
stat = StatusSerializer(read_only=True, source='latest_stat')
|
|
|
|
class Meta:
|
|
model = Terminal
|
|
fields_mini = ['id', 'name']
|
|
fields_small = fields_mini + [
|
|
'type', 'remote_addr', 'http_port', 'ssh_port',
|
|
'session_online', 'command_storage', 'replay_storage',
|
|
'is_accepted', "is_active", 'is_alive',
|
|
'date_created', 'comment',
|
|
]
|
|
fields_fk = ['status', 'status_display', 'stat']
|
|
fields = fields_small + fields_fk
|
|
read_only_fields = ['type', 'date_created']
|
|
extra_kwargs = {
|
|
'command_storage': {'required': True, },
|
|
'replay_storage': {'required': True, },
|
|
}
|
|
|
|
@staticmethod
|
|
def get_kwargs_may_be_uuid(value):
|
|
kwargs = {}
|
|
if is_uuid(value):
|
|
kwargs['id'] = value
|
|
else:
|
|
kwargs['name'] = value
|
|
return kwargs
|
|
|
|
def validate_command_storage(self, value):
|
|
kwargs = self.get_kwargs_may_be_uuid(value)
|
|
storage = CommandStorage.objects.filter(**kwargs).first()
|
|
if storage:
|
|
return storage.name
|
|
else:
|
|
raise serializers.ValidationError(_('Not found'))
|
|
|
|
def validate_replay_storage(self, value):
|
|
kwargs = self.get_kwargs_may_be_uuid(value)
|
|
storage = ReplayStorage.objects.filter(**kwargs).first()
|
|
if storage:
|
|
return storage.name
|
|
else:
|
|
raise serializers.ValidationError(_('Not found'))
|
|
|
|
|
|
class TaskSerializer(BulkModelSerializer):
|
|
class Meta:
|
|
fields = '__all__'
|
|
model = Task
|
|
ref_name = 'TerminalTaskSerializer'
|
|
|
|
|
|
class TerminalRegistrationSerializer(serializers.ModelSerializer):
|
|
service_account = ServiceAccountSerializer(read_only=True)
|
|
|
|
class Meta:
|
|
model = Terminal
|
|
fields = ['name', 'type', 'comment', 'service_account', 'remote_addr']
|
|
extra_kwargs = {
|
|
'name': {'max_length': 1024},
|
|
'remote_addr': {'read_only': True}
|
|
}
|
|
|
|
def is_valid(self, raise_exception=False):
|
|
valid = super().is_valid(raise_exception=raise_exception)
|
|
if not valid:
|
|
return valid
|
|
name = self.validated_data.get('name')
|
|
if len(name) > 128:
|
|
self.validated_data['comment'] = name
|
|
name = '{}...{}'.format(name[:32], name[-32:])
|
|
self.validated_data['name'] = name
|
|
|
|
data = {'name': name}
|
|
kwargs = {'data': data}
|
|
if self.instance and self.instance.user:
|
|
kwargs['instance'] = self.instance.user
|
|
self.service_account = ServiceAccountSerializer(**kwargs)
|
|
valid = self.service_account.is_valid(raise_exception=True)
|
|
return valid
|
|
|
|
def create(self, validated_data):
|
|
instance = super().create(validated_data)
|
|
request = self.context.get('request')
|
|
instance.is_accepted = True
|
|
if request:
|
|
instance.remote_addr = get_request_ip(request)
|
|
sa = self.service_account.create(validated_data)
|
|
sa.system_roles.add_role_system_component()
|
|
instance.user = sa
|
|
instance.command_storage = CommandStorage.default().name
|
|
instance.replay_storage = ReplayStorage.default().name
|
|
instance.save()
|
|
return instance
|