views.py 4.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. from django.template import RequestContext
  2. from django.utils.translation import ugettext as _
  3. from misago.banning.models import check_ban
  4. from misago.banning.decorators import block_banned
  5. from misago.banning.views import error_banned
  6. from misago.bruteforce.decorators import block_jammed
  7. from misago.forms.layouts import FormLayout
  8. from misago.messages import Message
  9. from misago.authn.decorators import block_authenticated
  10. from misago.resetpswd.forms import UserResetPasswordForm
  11. from misago.users.models import User
  12. from misago.views import redirect_message, error404
  13. from misago.utils import get_random_string
  14. @block_banned
  15. @block_authenticated
  16. @block_jammed
  17. def form(request):
  18. message = None
  19. if request.method == 'POST':
  20. form = UserResetPasswordForm(request.POST, request=request)
  21. if form.is_valid():
  22. user = form.found_user
  23. user_ban = check_ban(username=user.username, email=user.email)
  24. if user_ban:
  25. return error_banned(request, user, user_ban)
  26. elif user.activation != User.ACTIVATION_NONE:
  27. return redirect_message(request, Message(_("%(username)s, your account has to be activated in order for you to be able to request new password.") % {'username': user.username}), 'info')
  28. user.token = get_random_string(12)
  29. user.save(force_update=True)
  30. user.email_user(
  31. request,
  32. 'users/password/confirm',
  33. _("Confirm New Password Request")
  34. )
  35. return redirect_message(request, Message(_("%(username)s, new password request confirmation has been sent to %{email}s.") % {'username': user.username, 'email': user.email}), 'info')
  36. else:
  37. message = Message(form.non_field_errors()[0], 'error')
  38. else:
  39. form = UserSendSpecialMailForm(request=request)
  40. return request.theme.render_to_response('reset_password.html',
  41. {
  42. 'message': message,
  43. 'form': FormLayout(form),
  44. },
  45. context_instance=RequestContext(request));
  46. @block_banned
  47. @block_authenticated
  48. @block_jammed
  49. def reset(request, username="", user="0", token=""):
  50. user = int(user)
  51. try:
  52. user = User.objects.get(pk=user)
  53. user_ban = check_ban(username=user.username, email=user.email)
  54. if user_ban:
  55. return error_banned(request, user, user_ban)
  56. if user.activation != User.ACTIVATION_NONE:
  57. return redirect_message(request, Message(_("%(username)s, your account has to be activated in order for you to be able to request new password.") % {'username': user.username}), 'info')
  58. if not token or not user.token or user.token != token:
  59. return redirect_message(request, Message(_("%(username)s, request confirmation link is invalid. Please request new confirmation link.") % {'username': user.username}), 'error')
  60. new_password = get_random_string(6)
  61. user.token = None
  62. user.set_password(new_password)
  63. user.save(force_update=True)
  64. # Logout signed in and kill remember me tokens
  65. Session.objects.filter(user=user).update(user=None)
  66. Token.objects.filter(user=user).delete()
  67. # Set flash and mail new password
  68. user.email_user(
  69. request,
  70. 'users/password/new',
  71. _("Your New Password"),
  72. {'password': new_password}
  73. )
  74. return redirect_message(request, Message(_("%(username)s, your password has been changed with new one that was sent to %{email}s.") % {'username': user.username, 'email': user.email}), 'success')
  75. except User.DoesNotExist:
  76. return error404(request)