mirror of https://github.com/jumpserver/jumpserver
				
				
				
			
		
			
				
	
	
		
			91 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Python
		
	
	
			
		
		
	
	
			91 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Python
		
	
	
| from django.utils.translation import gettext_lazy as _
 | |
| from rest_framework import serializers
 | |
| 
 | |
| from common.utils import get_request_ip
 | |
| from common.serializers import CommonModelSerializer
 | |
| from common.serializers.fields import EncryptedField
 | |
| from perms.serializers.permission import ActionChoicesField
 | |
| from ..models import ConnectionToken, AdminConnectionToken
 | |
| from orgs.mixins.serializers import OrgResourceModelSerializerMixin
 | |
| 
 | |
| __all__ = [
 | |
|     'ConnectionTokenSerializer', 'SuperConnectionTokenSerializer',
 | |
|     'ConnectionTokenReusableSerializer', 'AdminConnectionTokenSerializer',
 | |
| ]
 | |
| 
 | |
| 
 | |
| class ConnectionTokenSerializer(OrgResourceModelSerializerMixin):
 | |
|     expire_time = serializers.IntegerField(read_only=True, label=_('Expired time'))
 | |
|     input_secret = EncryptedField(
 | |
|         label=_("Input secret"), max_length=40960, required=False, allow_blank=True
 | |
|     )
 | |
|     from_ticket_info = serializers.SerializerMethodField(label=_("Ticket info"))
 | |
|     actions = ActionChoicesField(read_only=True, label=_("Actions"))
 | |
| 
 | |
|     class Meta:
 | |
|         model = ConnectionToken
 | |
|         fields_mini = ['id', 'value']
 | |
|         fields_small = fields_mini + [
 | |
|             'user', 'asset', 'account', 'input_username', 'input_secret',
 | |
|             'connect_method', 'connect_options', 'protocol', 'actions',
 | |
|             'is_active', 'is_reusable', 'from_ticket', 'from_ticket_info',
 | |
|             'date_expired', 'date_created', 'date_updated', 'created_by',
 | |
|             'updated_by', 'org_id', 'org_name', 'face_monitor_token',
 | |
|             'remote_addr',
 | |
|         ]
 | |
|         read_only_fields = [
 | |
|             # 普通 Token 不支持指定 user
 | |
|             'user', 'expire_time', 'is_expired', 'date_expired',
 | |
|             'user_display', 'asset_display',
 | |
|         ]
 | |
|         fields = fields_small + read_only_fields
 | |
|         extra_kwargs = {
 | |
|             'face_monitor_token': {'read_only': True},
 | |
|             'from_ticket': {'read_only': True},
 | |
|             'value': {'read_only': True},
 | |
|             'is_expired': {'read_only': True, 'label': _('Is expired')},
 | |
|             'org_name': {'label': _("Org name")},
 | |
|         }
 | |
| 
 | |
|     def get_request_user(self):
 | |
|         request = self.context.get('request')
 | |
|         user = request.user if request else None
 | |
|         return user
 | |
| 
 | |
|     def get_user(self, attrs):
 | |
|         return self.get_request_user()
 | |
| 
 | |
|     def create(self, validated_data):
 | |
|         request = self.context.get('request')
 | |
|         if request:
 | |
|             validated_data['remote_addr'] = get_request_ip(request)
 | |
|         return super().create(validated_data)
 | |
| 
 | |
|     def get_from_ticket_info(self, instance) -> dict:
 | |
|         if not instance.from_ticket:
 | |
|             return {}
 | |
|         user = self.get_request_user()
 | |
|         info = instance.from_ticket.get_extra_info_of_review(user=user)
 | |
|         return info
 | |
| 
 | |
| 
 | |
| class ConnectionTokenReusableSerializer(CommonModelSerializer):
 | |
|     class Meta:
 | |
|         model = ConnectionToken
 | |
|         fields = ['id', 'date_expired', 'is_reusable']
 | |
|         can_update_fields = ['is_reusable']
 | |
|         read_only_fields = list(set(fields) - set(can_update_fields))
 | |
| 
 | |
| 
 | |
| class SuperConnectionTokenSerializer(ConnectionTokenSerializer):
 | |
|     class Meta(ConnectionTokenSerializer.Meta):
 | |
|         read_only_fields = list(set(ConnectionTokenSerializer.Meta.read_only_fields) - {'user'})
 | |
| 
 | |
|     def get_user(self, attrs):
 | |
|         return attrs.get('user')
 | |
| 
 | |
| 
 | |
| class AdminConnectionTokenSerializer(ConnectionTokenSerializer):
 | |
|     class Meta(ConnectionTokenSerializer.Meta):
 | |
|         model = AdminConnectionToken
 |