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