serializers.py 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. from rest_framework import serializers
  2. from rest_framework.validators import UniqueTogetherValidator
  3. from taggit_serializer.serializers import TaggitSerializer, TagListSerializerField
  4. from dcim.api.nested_serializers import NestedDeviceSerializer
  5. from extras.api.customfields import CustomFieldModelSerializer
  6. from secrets.models import Secret, SecretRole
  7. from utilities.api import ValidatedModelSerializer
  8. from .nested_serializers import *
  9. #
  10. # Secrets
  11. #
  12. class SecretRoleSerializer(ValidatedModelSerializer):
  13. secret_count = serializers.IntegerField(read_only=True)
  14. class Meta:
  15. model = SecretRole
  16. fields = ['id', 'name', 'slug', 'secret_count']
  17. class SecretSerializer(TaggitSerializer, CustomFieldModelSerializer):
  18. device = NestedDeviceSerializer()
  19. role = NestedSecretRoleSerializer()
  20. plaintext = serializers.CharField()
  21. tags = TagListSerializerField(required=False)
  22. class Meta:
  23. model = Secret
  24. fields = [
  25. 'id', 'device', 'role', 'name', 'plaintext', 'hash', 'tags', 'custom_fields', 'created', 'last_updated',
  26. ]
  27. validators = []
  28. def validate(self, data):
  29. # Encrypt plaintext data using the master key provided from the view context
  30. if data.get('plaintext'):
  31. s = Secret(plaintext=data['plaintext'])
  32. s.encrypt(self.context['master_key'])
  33. data['ciphertext'] = s.ciphertext
  34. data['hash'] = s.hash
  35. # Validate uniqueness of name if one has been provided.
  36. if data.get('name'):
  37. validator = UniqueTogetherValidator(queryset=Secret.objects.all(), fields=('device', 'role', 'name'))
  38. validator.set_context(self)
  39. validator(data)
  40. # Enforce model validation
  41. super().validate(data)
  42. return data