signature.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. from rest_framework.response import Response
  2. from django.core.exceptions import PermissionDenied
  3. from django.utils.translation import ugettext as _
  4. from misago.conf import settings
  5. from misago.core.utils import format_plaintext_for_html
  6. from misago.users.serializers import EditSignatureSerializer
  7. from misago.users.signatures import is_user_signature_valid, set_user_signature
  8. def signature_endpoint(request):
  9. user = request.user
  10. if not user.acl_cache['can_have_signature']:
  11. raise PermissionDenied(_("You don't have permission to change signature."))
  12. if user.is_signature_locked:
  13. if user.signature_lock_user_message:
  14. extra = format_plaintext_for_html(user.signature_lock_user_message)
  15. else:
  16. extra = None
  17. return Response(
  18. {
  19. 'detail': _("Your signature is locked. You can't change it."),
  20. 'extra': extra
  21. },
  22. status=403,
  23. )
  24. if request.method == 'POST':
  25. return edit_signature(request, user)
  26. return get_signature_options(user)
  27. def get_signature_options(user):
  28. options = {
  29. 'signature': None,
  30. 'limit': settings.signature_length_max,
  31. }
  32. if user.signature:
  33. options['signature'] = {
  34. 'plain': user.signature,
  35. 'html': user.signature_parsed,
  36. }
  37. if not is_user_signature_valid(user):
  38. options['signature']['html'] = None
  39. return Response(options)
  40. def edit_signature(request, user):
  41. serializer = EditSignatureSerializer(user, data=request.data)
  42. serializer.is_valid(raise_exception=True)
  43. set_user_signature(request, user, serializer.validated_data['signature'])
  44. user.save(update_fields=['signature', 'signature_parsed', 'signature_checksum'])
  45. return get_signature_options(user)