serializers.py 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. from django.contrib.contenttypes.models import ContentType
  2. from drf_yasg.utils import swagger_serializer_method
  3. from rest_framework import serializers
  4. from netbox.api import ContentTypeField
  5. from netbox.api.serializers import OrganizationalModelSerializer, PrimaryModelSerializer
  6. from secrets.constants import SECRET_ASSIGNMENT_MODELS
  7. from secrets.models import Secret, SecretRole
  8. from utilities.api import get_serializer_for_model
  9. from .nested_serializers import *
  10. #
  11. # Secrets
  12. #
  13. class SecretRoleSerializer(OrganizationalModelSerializer):
  14. url = serializers.HyperlinkedIdentityField(view_name='secrets-api:secretrole-detail')
  15. secret_count = serializers.IntegerField(read_only=True)
  16. class Meta:
  17. model = SecretRole
  18. fields = [
  19. 'id', 'url', 'display', 'name', 'slug', 'description', 'custom_fields', 'created', 'last_updated',
  20. 'secret_count',
  21. ]
  22. class SecretSerializer(PrimaryModelSerializer):
  23. url = serializers.HyperlinkedIdentityField(view_name='secrets-api:secret-detail')
  24. assigned_object_type = ContentTypeField(
  25. queryset=ContentType.objects.filter(SECRET_ASSIGNMENT_MODELS)
  26. )
  27. assigned_object = serializers.SerializerMethodField(read_only=True)
  28. role = NestedSecretRoleSerializer()
  29. plaintext = serializers.CharField()
  30. class Meta:
  31. model = Secret
  32. fields = [
  33. 'id', 'url', 'display', 'assigned_object_type', 'assigned_object_id', 'assigned_object', 'role', 'name',
  34. 'plaintext', 'hash', 'tags', 'custom_fields', 'created', 'last_updated',
  35. ]
  36. validators = []
  37. @swagger_serializer_method(serializer_or_field=serializers.DictField)
  38. def get_assigned_object(self, obj):
  39. serializer = get_serializer_for_model(obj.assigned_object, prefix='Nested')
  40. context = {'request': self.context['request']}
  41. return serializer(obj.assigned_object, context=context).data
  42. def validate(self, data):
  43. # Encrypt plaintext data using the master key provided from the view context
  44. if data.get('plaintext'):
  45. s = Secret(plaintext=data['plaintext'])
  46. s.encrypt(self.context['master_key'])
  47. data['ciphertext'] = s.ciphertext
  48. data['hash'] = s.hash
  49. super().validate(data)
  50. return data