views.py 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  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.admin import site
  7. from misago.banning.decorators import block_banned
  8. from misago.forms.layouts import FormLayout
  9. from misago.messages import Message
  10. from misago.security import get_random_string
  11. import misago.security.auth as auth
  12. from misago.security.auth import AuthException, auth_admin, auth_forum, sign_user_in
  13. from misago.security.decorators import *
  14. from misago.security.models import SignInAttempt
  15. from misago.sessions.models import Token
  16. from forms import SignInForm
  17. @block_banned
  18. @block_authenticated
  19. @block_jammed
  20. def signin(request):
  21. message = request.messages.get_message('security')
  22. if request.method == 'POST':
  23. form = SignInForm(
  24. request.POST,
  25. show_remember_me=not request.firewall.admin and request.settings['remember_me_allow'],
  26. show_stay_hidden=not request.firewall.admin and request.settings['sessions_hidden'],
  27. request=request
  28. )
  29. if form.is_valid():
  30. try:
  31. # Configure correct auth and redirect links
  32. if request.firewall.admin:
  33. auth_method = auth_admin
  34. success_redirect = reverse(site.get_admin_index())
  35. else:
  36. auth_method = auth_forum
  37. success_redirect = reverse('index')
  38. # Authenticate user
  39. user = auth_method(
  40. request,
  41. form.cleaned_data['user_email'],
  42. form.cleaned_data['user_password'],
  43. )
  44. if not request.firewall.admin and request.settings['sessions_hidden'] and form.cleaned_data['user_stay_hidden']:
  45. request.session.hidden = True
  46. sign_user_in(request, user, request.session.hidden)
  47. remember_me_token = False
  48. if not request.firewall.admin and request.settings['remember_me_allow'] and form.cleaned_data['user_remember_me']:
  49. remember_me_token = get_random_string(42)
  50. remember_me = Token(
  51. id=remember_me_token,
  52. user=user,
  53. created=timezone.now(),
  54. accessed=timezone.now(),
  55. hidden=request.session.hidden
  56. )
  57. remember_me.save()
  58. if remember_me_token:
  59. request.cookie_jar.set('TOKEN', remember_me_token, True)
  60. request.messages.set_flash(Message(request, 'security/signed_in', extra={'user': user}), 'success', 'security')
  61. return redirect(success_redirect)
  62. except AuthException as e:
  63. message = Message(request, e.type, extra={'user':e.user})
  64. message.type = 'error'
  65. # If not in Admin, register failed attempt
  66. if not request.firewall.admin and e.type == auth.CREDENTIALS:
  67. SignInAttempt.objects.register_attempt(request.session.get_ip(request))
  68. # Have we jammed our account?
  69. if SignInAttempt.objects.is_jammed(request.settings, request.session.get_ip(request)):
  70. request.jam.expires = timezone.now()
  71. return redirect(reverse('sign_in'))
  72. else:
  73. message = Message(request, form.non_field_errors()[0])
  74. message.type = 'error'
  75. else:
  76. form = SignInForm(
  77. show_remember_me=not request.firewall.admin and request.settings['remember_me_allow'],
  78. show_stay_hidden=not request.firewall.admin and request.settings['sessions_hidden'],
  79. request=request
  80. )
  81. return request.theme.render_to_response('signin.html',
  82. {
  83. 'message': message,
  84. 'form': FormLayout(form, [
  85. (
  86. None,
  87. [('user_email', {'attrs': {'placeholder': _("Enter your e-mail")}}), ('user_password', {'has_value': False, 'placeholder': _("Enter your password")})]
  88. ),
  89. (
  90. None,
  91. ['user_remember_me', 'user_stay_hidden'],
  92. ),
  93. ]),
  94. 'hide_signin': True,
  95. },
  96. context_instance=RequestContext(request));
  97. @block_guest
  98. @check_csrf
  99. def signout(request):
  100. user = request.user
  101. request.session.sign_out(request)
  102. request.messages.set_flash(Message(request, 'security/signed_out', extra={'user': user}), 'info', 'security')
  103. if request.firewall.admin:
  104. return redirect(reverse(site.get_admin_index()))
  105. return redirect(reverse('index'))