moderation.py 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. from datetime import timedelta
  2. from django import forms
  3. from django.contrib.auth import get_user_model
  4. from django.utils import timezone
  5. from django.utils.translation import ugettext_lazy as _
  6. from django.utils.translation import ungettext
  7. from misago.conf import settings
  8. from misago.core.forms import YesNoSwitch
  9. from ..bans import ban_user
  10. class ModerateAvatarForm(forms.ModelForm):
  11. is_avatar_locked = YesNoSwitch()
  12. avatar_lock_user_message = forms.CharField(required=False)
  13. avatar_lock_staff_message = forms.CharField(required=False)
  14. class Meta:
  15. model = get_user_model()
  16. fields = [
  17. 'is_avatar_locked',
  18. 'avatar_lock_user_message',
  19. 'avatar_lock_staff_message',
  20. ]
  21. class ModerateSignatureForm(forms.ModelForm):
  22. signature = forms.CharField(
  23. label=_("Signature contents"),
  24. widget=forms.Textarea(attrs={'rows': 3}),
  25. required=False)
  26. is_signature_locked = YesNoSwitch(
  27. label=_("Lock signature"),
  28. help_text=_("Setting this to yes will stop user from "
  29. "making changes to his/her signature."))
  30. signature_lock_user_message = forms.CharField(
  31. label=_("User message"),
  32. help_text=_("Optional message to user explaining "
  33. "why his/hers signature is locked."),
  34. widget=forms.Textarea(attrs={'rows': 3}),
  35. required=False)
  36. signature_lock_staff_message = forms.CharField(
  37. label=_("Staff message"),
  38. help_text=_("Optional message to team members explaining "
  39. "why user signature is locked."),
  40. widget=forms.Textarea(attrs={'rows': 3}),
  41. required=False)
  42. class Meta:
  43. model = get_user_model()
  44. fields = [
  45. 'signature',
  46. 'is_signature_locked',
  47. 'signature_lock_user_message',
  48. 'signature_lock_staff_message'
  49. ]
  50. def clean_signature(self):
  51. data = self.cleaned_data['signature']
  52. length_limit = settings.signature_length_max
  53. if len(data) > length_limit:
  54. raise forms.ValidationError(ungettext(
  55. "Signature can't be longer than %(limit)s character.",
  56. "Signature can't be longer than %(limit)s characters.",
  57. length_limit) % {'limit': length_limit})
  58. return data
  59. class BanForm(forms.Form):
  60. user_message = forms.CharField(
  61. label=_("User message"), required=False, max_length=1000,
  62. help_text=_("Optional message displayed to user "
  63. "instead of default one."),
  64. widget=forms.Textarea(attrs={'rows': 3}),
  65. error_messages={
  66. 'max_length': _("Message can't be longer than 1000 characters.")
  67. })
  68. staff_message = forms.CharField(
  69. label=_("Team message"), required=False, max_length=1000,
  70. help_text=_("Optional ban message for moderators and administrators."),
  71. widget=forms.Textarea(attrs={'rows': 3}),
  72. error_messages={
  73. 'max_length': _("Message can't be longer than 1000 characters.")
  74. })
  75. expires_on = forms.DateTimeField(
  76. label=_("Expires on"),
  77. required=False, localize=True,
  78. help_text=_('Leave this field empty for this ban to never expire.'))
  79. def __init__(self, *args, **kwargs):
  80. self.user = kwargs.pop('user')
  81. super(BanForm, self).__init__(*args, **kwargs)
  82. if self.user.acl_['max_ban_length']:
  83. message = ungettext(
  84. "Required. Can't be longer than %(days)s day.",
  85. "Required. Can't be longer than %(days)s days.",
  86. self.user.acl_['max_ban_length'])
  87. message = message % {'days': self.user.acl_['max_ban_length']}
  88. self['expires_on'].field.help_text = message
  89. def clean_expires_on(self):
  90. data = self.cleaned_data['expires_on']
  91. if self.user.acl_['max_ban_length']:
  92. max_ban_length = timedelta(days=self.user.acl_['max_ban_length'])
  93. if not data or data > (timezone.now() + max_ban_length).date():
  94. message = ungettext(
  95. "You can't set bans longer than %(days)s day.",
  96. "You can't set bans longer than %(days)s days.",
  97. self.user.acl_['max_ban_length'])
  98. message = message % {'days': self.user.acl_['max_ban_length']}
  99. raise forms.ValidationError(message)
  100. elif data and data < timezone.now().date():
  101. raise forms.ValidationError(_("Expiration date is in past."))
  102. return data
  103. def ban_user(self):
  104. ban_user(self.user,
  105. user_message=self.cleaned_data['user_message'],
  106. staff_message=self.cleaned_data['staff_message'],
  107. expires_on=self.cleaned_data['expires_on'])