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