__init__.py 4.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  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.forms.layouts import FormLayout
  8. from misago.messages import Message
  9. from misago.security.auth import sign_user_in
  10. from misago.security.decorators import *
  11. from misago.users.forms import *
  12. from misago.users.models import User, Group
  13. from misago.views import error403
  14. @block_banned
  15. @block_authenticated
  16. @block_jammed
  17. def register(request):
  18. if request.settings['account_activation'] == 'block':
  19. return error403(request, Message(request, 'auth/registrations_off'))
  20. message = None
  21. if request.method == 'POST':
  22. form = UserRegisterForm(request.POST, request=request)
  23. if form.is_valid():
  24. need_activation = 0
  25. if request.settings['account_activation'] == 'user':
  26. need_activation = User.ACTIVATION_USER
  27. if request.settings['account_activation'] == 'admin':
  28. need_activation = User.ACTIVATION_ADMIN
  29. new_user = User.objects.create_user(
  30. form.cleaned_data['username'],
  31. form.cleaned_data['email'],
  32. form.cleaned_data['password'],
  33. Group.objects.get(pk=3), # Registered members
  34. ip=request.session.get_ip(request),
  35. activation=need_activation,
  36. request=request
  37. )
  38. if need_activation == User.ACTIVATION_NONE:
  39. # No need for activation, sign in user
  40. sign_user_in(request, new_user)
  41. request.messages.set_flash(Message(request, 'auth/registered_activation_none', extra={'user':new_user}), 'success')
  42. if need_activation == User.ACTIVATION_USER:
  43. # Mail user activation e-mail
  44. request.messages.set_flash(Message(request, 'auth/registered_activation_user', extra={'user':new_user}), 'info')
  45. new_user.email_user(
  46. request,
  47. 'auth/activation_0',
  48. _("Welcome aboard, %(username)s!" % {'username': new_user.username}),
  49. )
  50. if need_activation == User.ACTIVATION_ADMIN:
  51. # Require admin activation
  52. request.messages.set_flash(Message(request, 'users/registered_activation_admin', extra={'user':new_user}), 'info')
  53. new_user.email_user(
  54. request,
  55. ('auth/activation_%s' % need_activation),
  56. _("Welcome aboard, %(username)s!" % {'username': new_user.username}),
  57. {'password': form.cleaned_data['password']}
  58. )
  59. return redirect(reverse('index'))
  60. else:
  61. message = Message(request, form.non_field_errors()[0])
  62. if request.settings['registrations_jams']:
  63. SignInAttempt.objects.register_attempt(request.session.get_ip(request))
  64. # Have we jammed our account?
  65. if SignInAttempt.objects.is_jammed(request.session.get_ip(request)):
  66. request.jam.expires = timezone.now()
  67. return redirect(reverse('register'))
  68. else:
  69. form = UserRegisterForm(request=request)
  70. return request.theme.render_to_response('auth/register.html',
  71. {
  72. 'message': message,
  73. 'form': FormLayout(form),
  74. 'hide_signin': True,
  75. },
  76. context_instance=RequestContext(request));