views.py 3.7 KB

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