views.py 4.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. from django.template import RequestContext
  2. from django.utils.translation import ugettext as _
  3. from misago.banning.models import check_ban
  4. from misago.banning.decorators import block_banned
  5. from misago.banning.views import error_banned
  6. from misago.crawlers.decorators import block_crawlers
  7. from misago.forms.layouts import FormLayout
  8. from misago.authn.methods import sign_user_in
  9. from misago.authn.decorators import block_authenticated
  10. from misago.activation.forms import UserSendActivationMailForm
  11. from misago.bruteforce.decorators import block_jammed
  12. from misago.messages import Message
  13. from misago.users.models import User
  14. from misago.views import redirect_message, error404
  15. @block_crawlers
  16. @block_banned
  17. @block_authenticated
  18. @block_jammed
  19. def form(request):
  20. message = None
  21. if request.method == 'POST':
  22. form = UserSendActivationMailForm(request.POST, request=request)
  23. if form.is_valid():
  24. user = form.found_user
  25. user_ban = check_ban(username=user.username, email=user.email)
  26. if user_ban:
  27. return error_banned(request, user, user_ban)
  28. if user.activation == User.ACTIVATION_NONE:
  29. return redirect_message(request, Message(_("%(username)s, your account is already active.") % {'username': user.username}), 'info')
  30. if user.activation == User.ACTIVATION_ADMIN:
  31. return redirect_message(request, Message(_("%(username)s, only board administrator can activate your account.") % {'username': user.username}), 'info')
  32. user.email_user(
  33. request,
  34. 'users/activation/resend',
  35. _("Account Activation"),
  36. )
  37. return redirect_message(request, Message(_("%(username)s, e-mail containing new activation link has been sent to %(email)s.") % {'username': user.username, 'email': user.email}), 'success')
  38. else:
  39. message = Message(form.non_field_errors()[0], 'error')
  40. else:
  41. form = UserSendActivationMailForm(request=request)
  42. return request.theme.render_to_response('resend_activation.html',
  43. {
  44. 'message': message,
  45. 'form': FormLayout(form),
  46. },
  47. context_instance=RequestContext(request));
  48. @block_banned
  49. @block_authenticated
  50. @block_jammed
  51. def activate(request, username="", user="0", token=""):
  52. user = int(user)
  53. try:
  54. user = User.objects.get(pk=user)
  55. current_activation = user.activation
  56. # Run checks
  57. user_ban = check_ban(username=user.username, email=user.email)
  58. if user_ban:
  59. return error_banned(request, user, user_ban)
  60. if user.activation == User.ACTIVATION_NONE:
  61. return redirect_message(request, Message(_("%(username)s, your account is already active.") % {'username': user.username}), 'info')
  62. if user.activation == User.ACTIVATION_ADMIN:
  63. return redirect_message(request, Message(_("%(username)s, only board administrator can activate your account.") % {'username': user.username}), 'info')
  64. if not token or not user.token or user.token != token:
  65. return redirect_message(request, Message(_("%(username)s, your activation link is invalid. Try again or request new activation e-mail.") % {'username': user.username}), 'error')
  66. # Activate and sign in our member
  67. user.activation = User.ACTIVATION_NONE
  68. sign_user_in(request, user)
  69. # Update monitor
  70. User.objects.resync_monitor(request.monitor)
  71. if current_activation == User.ACTIVATION_CREDENTIALS:
  72. return redirect_message(request, Message(_("%(username)s, your account has been successfully reactivated after change of sign-in credentials.") % {'username': user.username}), 'success')
  73. else:
  74. return redirect_message(request, Message(_("%(username)s, your account has been successfully activated. Welcome aboard!") % {'username': user.username}), 'success')
  75. except User.DoesNotExist:
  76. return error404(request)