moderation.py 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159
  1. from django.contrib import messages
  2. from django.contrib.auth import get_user_model
  3. from django.db import IntegrityError, transaction
  4. from django.shortcuts import redirect, render
  5. from django.utils.translation import ugettext as _
  6. from misago.acl import add_acl
  7. from misago.core.decorators import require_POST
  8. from misago.core.shortcuts import get_object_or_404, validate_slug
  9. from misago.markup import Editor
  10. from misago.users import avatars
  11. from misago.users.bans import get_user_ban
  12. from misago.users.decorators import deny_guests
  13. from misago.users.forms.rename import ChangeUsernameForm
  14. from misago.users.forms.modusers import (BanForm, ModerateAvatarForm,
  15. ModerateSignatureForm)
  16. from misago.users.models import Ban
  17. from misago.users.permissions.moderation import (allow_rename_user,
  18. allow_moderate_avatar,
  19. allow_moderate_signature,
  20. allow_ban_user,
  21. allow_lift_ban)
  22. from misago.users.permissions.delete import allow_delete_user
  23. from misago.users.signatures import set_user_signature
  24. from misago.users.sites import user_profile
  25. def user_moderation_view(required_permission=None):
  26. def wrap(f):
  27. @deny_guests
  28. @transaction.atomic
  29. def decorator(request, *args, **kwargs):
  30. queryset = get_user_model().objects.select_for_update()
  31. user_id = kwargs.pop('user_id')
  32. kwargs['user'] = get_object_or_404(queryset, id=user_id)
  33. validate_slug(kwargs['user'], kwargs.pop('user_slug'))
  34. add_acl(request.user, kwargs['user'])
  35. if required_permission:
  36. required_permission(request.user, kwargs['user'])
  37. return f(request, *args, **kwargs)
  38. return decorator
  39. return wrap
  40. @user_moderation_view(allow_rename_user)
  41. def rename(request, user):
  42. form = ChangeUsernameForm(user=user)
  43. if request.method == 'POST':
  44. old_username = user.username
  45. form = ChangeUsernameForm(request.POST, user=user)
  46. if form.is_valid():
  47. try:
  48. form.change_username(changed_by=user)
  49. message = _("%(old_username)s's username has been changed.")
  50. message = message % {'old_username': old_username}
  51. messages.success(request, message)
  52. return redirect(user_profile.get_default_link(),
  53. **{'user_slug': user.slug, 'user_id': user.pk})
  54. except IntegrityError:
  55. message = _("Error changing username. Please try again.")
  56. messages.error(request, message)
  57. return render(request, 'misago/modusers/rename.html',
  58. {'profile': user, 'form': form})
  59. @user_moderation_view(allow_moderate_avatar)
  60. def moderate_avatar(request, user):
  61. form = ModerateAvatarForm(instance=user)
  62. return render(request, 'misago/modusers/avatar.html',
  63. {'profile': user, 'form': form})
  64. @user_moderation_view(allow_moderate_signature)
  65. def moderate_signature(request, user):
  66. form = ModerateSignatureForm(instance=user)
  67. if request.method == 'POST':
  68. form = ModerateSignatureForm(request.POST, instance=user)
  69. if form.is_valid():
  70. changed_fields = (
  71. 'signature',
  72. 'signature_parsed',
  73. 'signature_checksum',
  74. 'is_signature_banned',
  75. 'signature_ban_user_message',
  76. 'signature_ban_staff_message'
  77. )
  78. set_user_signature(user, form.cleaned_data['signature'])
  79. user.save(update_fields=changed_fields)
  80. message = _("%(username)s's signature has been moderated.")
  81. message = message % {'username': user.username}
  82. messages.success(request, message)
  83. if 'stay' not in request.POST:
  84. return redirect(user_profile.get_default_link(),
  85. **{'user_slug': user.slug, 'user_id': user.pk})
  86. acl = user.acl
  87. editor = Editor(form['signature'],
  88. allow_blocks=acl['allow_signature_blocks'],
  89. allow_links=acl['allow_signature_links'],
  90. allow_images=acl['allow_signature_images'])
  91. return render(request, 'misago/modusers/signature.html',
  92. {'profile': user, 'form': form, 'editor': editor})
  93. @user_moderation_view(allow_ban_user)
  94. def ban_user(request, user):
  95. form = BanForm(user=user)
  96. if request.method == 'POST':
  97. form = BanForm(request.POST, user=user)
  98. if form.is_valid():
  99. form.ban_user()
  100. message = _("%(username)s has been banned.")
  101. messages.success(request, message % {'username': user.username})
  102. return redirect(user_profile.get_default_link(),
  103. **{'user_slug': user.slug, 'user_id': user.pk})
  104. return render(request, 'misago/modusers/ban.html',
  105. {'profile': user, 'form': form})
  106. @require_POST
  107. @user_moderation_view(allow_lift_ban)
  108. def lift_user_ban(request, user):
  109. user_ban = get_user_ban(user).ban
  110. user_ban.lift()
  111. user_ban.save()
  112. Ban.objects.invalidate_cache()
  113. message = _("%(username)s's ban has been lifted.")
  114. messages.success(request, message % {'username': user.username})
  115. return redirect(user_profile.get_default_link(),
  116. **{'user_slug': user.slug, 'user_id': user.pk})
  117. @require_POST
  118. @user_moderation_view(allow_delete_user)
  119. def delete(request, user):
  120. user.delete(delete_content=True)
  121. message = _("User %(username)s has been deleted.")
  122. messages.success(request, message % {'username': user.username})
  123. return redirect('misago:index')