serializers.py 1.4 KB

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