views.py 5.1 KB

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