views.py 4.0 KB

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