views.py 4.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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, sign in user
  41. sign_user_in(request, new_user)
  42. request.messages.set_flash(Message(_("Welcome aboard, %(username)s! Your account has been registered successfully.") % {'username': new_user.username}), 'success')
  43. if need_activation == User.ACTIVATION_USER:
  44. # Mail user activation e-mail
  45. 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')
  46. new_user.email_user(
  47. request,
  48. 'users/activation/user',
  49. _("Welcome aboard, %(username)s!") % {'username': new_user.username},
  50. )
  51. if need_activation == User.ACTIVATION_ADMIN:
  52. # Require admin activation
  53. 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')
  54. new_user.email_user(
  55. request,
  56. 'users/activation/admin',
  57. _("Welcome aboard, %(username)s!") % {'username': new_user.username},
  58. {'password': form.cleaned_data['password']}
  59. )
  60. return redirect(reverse('index'))
  61. else:
  62. message = Message(form.non_field_errors()[0], 'error')
  63. if request.settings['registrations_jams']:
  64. SignInAttempt.objects.register_attempt(request.session.get_ip(request))
  65. # Have we jammed our account?
  66. if SignInAttempt.objects.is_jammed(request.settings, request.session.get_ip(request)):
  67. request.jam.expires = timezone.now()
  68. return redirect(reverse('register'))
  69. else:
  70. form = UserRegisterForm(request=request)
  71. return request.theme.render_to_response('register.html',
  72. {
  73. 'message': message,
  74. 'form': FormLayout(form),
  75. 'hide_signin': True,
  76. },
  77. context_instance=RequestContext(request));