views.py 5.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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.forms.layouts import FormLayout
  10. from misago.messages import Message
  11. from misago.authn.decorators import block_authenticated
  12. from misago.authn.methods import sign_user_in
  13. from misago.register.forms import UserRegisterForm
  14. from misago.users.models import User
  15. from misago.views import redirect_message
  16. @block_banned
  17. @block_authenticated
  18. @block_jammed
  19. def form(request):
  20. if request.settings['account_activation'] == 'block':
  21. return redirect_message(request, Message(_("We are sorry but we don't allow new members registrations at this time.")), 'info')
  22. message = None
  23. if request.method == 'POST':
  24. form = UserRegisterForm(request.POST, request=request)
  25. if form.is_valid():
  26. need_activation = 0
  27. if request.settings['account_activation'] == 'user':
  28. need_activation = User.ACTIVATION_USER
  29. if request.settings['account_activation'] == 'admin':
  30. need_activation = User.ACTIVATION_ADMIN
  31. new_user = User.objects.create_user(
  32. form.cleaned_data['username'],
  33. form.cleaned_data['email'],
  34. form.cleaned_data['password'],
  35. ip=request.session.get_ip(request),
  36. activation=need_activation,
  37. request=request
  38. )
  39. if need_activation == User.ACTIVATION_NONE:
  40. # No need for activation, update monitor with fresh data
  41. request.monitor['users'] = int(request.monitor['users']) + 1
  42. request.monitor['last_user'] = new_user.pk
  43. request.monitor['last_user_name'] = new_user.username
  44. request.monitor['last_user_slug'] = new_user.username_slug
  45. # Sign in user
  46. sign_user_in(request, new_user)
  47. request.messages.set_flash(Message(_("Welcome aboard, %(username)s! Your account has been registered successfully.") % {'username': new_user.username}), 'success')
  48. if need_activation == User.ACTIVATION_USER:
  49. # Mail user activation e-mail
  50. 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')
  51. new_user.email_user(
  52. request,
  53. 'users/activation/user',
  54. _("Welcome aboard, %(username)s!") % {'username': new_user.username},
  55. )
  56. if need_activation == User.ACTIVATION_ADMIN:
  57. # Require admin activation
  58. 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')
  59. new_user.email_user(
  60. request,
  61. 'users/activation/admin',
  62. _("Welcome aboard, %(username)s!") % {'username': new_user.username},
  63. {'password': form.cleaned_data['password']}
  64. )
  65. return redirect(reverse('index'))
  66. else:
  67. message = Message(form.non_field_errors()[0], 'error')
  68. if request.settings['registrations_jams']:
  69. SignInAttempt.objects.register_attempt(request.session.get_ip(request))
  70. # Have we jammed our account?
  71. if SignInAttempt.objects.is_jammed(request.settings, request.session.get_ip(request)):
  72. request.jam.expires = timezone.now()
  73. return redirect(reverse('register'))
  74. else:
  75. form = UserRegisterForm(request=request)
  76. return request.theme.render_to_response('register.html',
  77. {
  78. 'message': message,
  79. 'form': FormLayout(form),
  80. 'hide_signin': True,
  81. },
  82. context_instance=RequestContext(request));