| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- from rest_framework import serializers
- from taggit_serializer.serializers import TaggitSerializer, TagListSerializerField
- from dcim.api.nested_serializers import NestedDeviceSerializer
- from extras.api.customfields import CustomFieldModelSerializer
- from secrets.models import Secret, SecretRole
- from utilities.api import ValidatedModelSerializer
- from .nested_serializers import *
- #
- # Secrets
- #
- class SecretRoleSerializer(ValidatedModelSerializer):
- secret_count = serializers.IntegerField(read_only=True)
- class Meta:
- model = SecretRole
- fields = ['id', 'name', 'slug', 'description', 'secret_count']
- class SecretSerializer(TaggitSerializer, CustomFieldModelSerializer):
- device = NestedDeviceSerializer()
- role = NestedSecretRoleSerializer()
- plaintext = serializers.CharField()
- tags = TagListSerializerField(required=False)
- class Meta:
- model = Secret
- fields = [
- 'id', 'device', 'role', 'name', 'plaintext', 'hash', 'tags', 'custom_fields', 'created', 'last_updated',
- ]
- validators = []
- def validate(self, data):
- # Encrypt plaintext data using the master key provided from the view context
- if data.get('plaintext'):
- s = Secret(plaintext=data['plaintext'])
- s.encrypt(self.context['master_key'])
- data['ciphertext'] = s.ciphertext
- data['hash'] = s.hash
- super().validate(data)
- return data
|