views.py 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. from django.core.urlresolvers import reverse
  2. from django.shortcuts import redirect
  3. from django.template import RequestContext
  4. from django.utils import timezone
  5. from django.utils.translation import ugettext as _
  6. from misago.banning.decorators import block_banned
  7. from misago.bruteforce.decorators import block_jammed
  8. from misago.bruteforce.models import SignInAttempt
  9. from misago.crawlers.decorators import block_crawlers
  10. from misago.forms.layouts import FormLayout
  11. from misago.messages import Message
  12. from misago.authn.decorators import block_authenticated
  13. from misago.authn.methods import sign_user_in
  14. from misago.register.forms import UserRegisterForm
  15. from misago.users.models import User
  16. from misago.views import redirect_message
  17. @block_crawlers
  18. @block_banned
  19. @block_authenticated
  20. @block_jammed
  21. def form(request):
  22. if request.settings['account_activation'] == 'block':
  23. return redirect_message(request, Message(_("We are sorry but we don't allow new members registrations at this time.")), 'info')
  24. message = None
  25. if request.method == 'POST':
  26. form = UserRegisterForm(request.POST, request=request)
  27. if form.is_valid():
  28. need_activation = 0
  29. if request.settings['account_activation'] == 'user':
  30. need_activation = User.ACTIVATION_USER
  31. if request.settings['account_activation'] == 'admin':
  32. need_activation = User.ACTIVATION_ADMIN
  33. new_user = User.objects.create_user(
  34. form.cleaned_data['username'],
  35. form.cleaned_data['email'],
  36. form.cleaned_data['password'],
  37. ip=request.session.get_ip(request),
  38. activation=need_activation,
  39. request=request
  40. )
  41. if need_activation == User.ACTIVATION_NONE:
  42. # Sign in user
  43. sign_user_in(request, new_user)
  44. request.messages.set_flash(Message(_("Welcome aboard, %(username)s! Your account has been registered successfully.") % {'username': new_user.username}), 'success')
  45. if need_activation == User.ACTIVATION_USER:
  46. # Mail user activation e-mail
  47. request.messages.set_flash(Message(_("%(username)s, your account has been registered, but you will have to activate it before you will be able to sign-in. We have sent you an e-mail with activation link.") % {'username': new_user.username}), 'info')
  48. new_user.email_user(
  49. request,
  50. 'users/activation/user',
  51. _("Welcome aboard, %(username)s!") % {'username': new_user.username},
  52. )
  53. if need_activation == User.ACTIVATION_ADMIN:
  54. # Require admin activation
  55. request.messages.set_flash(Message(_("%(username)s, Your account has been registered, but you won't be able to sign in until board administrator accepts it. We'll notify when this happens. Thank you for your patience!") % {'username': new_user.username}), 'info')
  56. new_user.email_user(
  57. request,
  58. 'users/activation/admin',
  59. _("Welcome aboard, %(username)s!") % {'username': new_user.username},
  60. {'password': form.cleaned_data['password']}
  61. )
  62. User.objects.resync_monitor(request.monitor)
  63. return redirect(reverse('index'))
  64. else:
  65. message = Message(form.non_field_errors()[0], 'error')
  66. if request.settings['registrations_jams']:
  67. SignInAttempt.objects.register_attempt(request.session.get_ip(request))
  68. # Have we jammed our account?
  69. if SignInAttempt.objects.is_jammed(request.settings, request.session.get_ip(request)):
  70. request.jam.expires = timezone.now()
  71. return redirect(reverse('register'))
  72. else:
  73. form = UserRegisterForm(request=request)
  74. return request.theme.render_to_response('register.html',
  75. {
  76. 'message': message,
  77. 'form': FormLayout(form),
  78. 'hide_signin': True,
  79. },
  80. context_instance=RequestContext(request));