auth.py 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. from rest_framework import serializers
  2. from django.contrib.auth import get_user_model
  3. from django.urls import reverse
  4. from misago.acl import serialize_acl
  5. from .user import UserSerializer
  6. UserModel = get_user_model()
  7. __all__ = [
  8. 'AuthenticatedUserSerializer',
  9. 'AnonymousUserSerializer',
  10. ]
  11. class AuthFlags(object):
  12. def get_is_authenticated(self, obj):
  13. return bool(obj.is_authenticated)
  14. def get_is_anonymous(self, obj):
  15. return bool(obj.is_anonymous)
  16. class AuthenticatedUserSerializer(UserSerializer, AuthFlags):
  17. email = serializers.SerializerMethodField()
  18. is_authenticated = serializers.SerializerMethodField()
  19. is_anonymous = serializers.SerializerMethodField()
  20. class Meta:
  21. model = UserModel
  22. fields = UserSerializer.Meta.fields + (
  23. 'is_hiding_presence', 'limits_private_thread_invites_to', 'subscribe_to_started_threads',
  24. 'subscribe_to_replied_threads', 'is_authenticated', 'is_anonymous',
  25. )
  26. def get_acl(self, obj):
  27. return serialize_acl(obj)
  28. def get_email(self, obj):
  29. return obj.email
  30. def get_api_url(self, obj):
  31. return {
  32. 'avatar': reverse('misago:api:user-avatar', kwargs={'pk': obj.pk}),
  33. 'options': reverse('misago:api:user-forum-options', kwargs={'pk': obj.pk}),
  34. 'username': reverse('misago:api:user-username', kwargs={'pk': obj.pk}),
  35. 'change_email': reverse('misago:api:user-change-email', kwargs={'pk': obj.pk}),
  36. 'change_password': reverse('misago:api:user-change-password', kwargs={'pk': obj.pk}),
  37. }
  38. AuthenticatedUserSerializer = AuthenticatedUserSerializer.exclude_fields(
  39. 'is_avatar_locked',
  40. 'is_blocked',
  41. 'is_followed',
  42. 'is_signature_locked',
  43. 'meta',
  44. 'signature',
  45. 'status',
  46. )
  47. class AnonymousUserSerializer(serializers.Serializer, AuthFlags):
  48. id = serializers.ReadOnlyField()
  49. acl = serializers.SerializerMethodField()
  50. is_authenticated = serializers.SerializerMethodField()
  51. is_anonymous = serializers.SerializerMethodField()
  52. def get_acl(self, obj):
  53. if hasattr(obj, 'acl_cache'):
  54. return serialize_acl(obj)
  55. else:
  56. return {}