password.py 3.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. from django.core.urlresolvers import reverse
  2. from django.shortcuts import redirect
  3. from django.template import RequestContext
  4. from django.utils.translation import ugettext as _
  5. from misago.banning.models import check_ban
  6. from misago.banning.decorators import block_banned
  7. from misago.banning.views import error_banned
  8. from misago.forms.layouts import FormLayout
  9. from misago.messages import Message
  10. from misago.security import get_random_string
  11. from misago.security.decorators import *
  12. from misago.users.forms import *
  13. from misago.users.models import User
  14. from misago.views import error403, error404
  15. @block_banned
  16. @block_authenticated
  17. @block_jammed
  18. def form(request):
  19. message = None
  20. if request.method == 'POST':
  21. form = UserSendSpecialMailForm(request.POST, request=request)
  22. if form.is_valid():
  23. user = form.found_user
  24. user_ban = check_ban(username=user.username, email=user.email)
  25. if user_ban:
  26. return error_banned(request, user, user_ban)
  27. elif user.activation != User.ACTIVATION_NONE:
  28. return error403(request, Message(request, 'users/activations/required', {'user': user}))
  29. user.token = get_random_string(12)
  30. user.save(force_update=True)
  31. request.messages.set_flash(Message(request, 'users/passwords/reset_confirm', extra={'user':user}), 'success')
  32. user.email_user(
  33. request,
  34. 'users/reset_confirm',
  35. _("Confirm New Password Request")
  36. )
  37. return redirect(reverse('index'))
  38. else:
  39. message = Message(request, form.non_field_errors()[0])
  40. else:
  41. form = UserSendSpecialMailForm(request=request)
  42. return request.theme.render_to_response('users/forgot_password.html',
  43. {
  44. 'message': message,
  45. 'form': FormLayout(form),
  46. },
  47. context_instance=RequestContext(request));
  48. @block_banned
  49. @block_authenticated
  50. @block_jammed
  51. def reset(request, username="", user="0", token=""):
  52. user = int(user)
  53. try:
  54. user = User.objects.get(pk=user)
  55. user_ban = check_ban(username=user.username, email=user.email)
  56. if user_ban:
  57. return error_banned(request, user, user_ban)
  58. if user.activation != User.ACTIVATION_NONE:
  59. return error403(request, Message(request, 'users/activations/required', {'user': user}))
  60. if not token or not user.token or user.token != token:
  61. return error403(request, Message(request, 'users/invalid_confirmation_link', {'user': user}))
  62. new_password = get_random_string(6)
  63. user.token = None
  64. user.set_password(new_password)
  65. user.save(force_update=True)
  66. # Logout signed in and kill remember me tokens
  67. Session.objects.filter(user=user).update(user=None)
  68. Token.objects.filter(user=user).delete()
  69. # Set flash and mail new password
  70. request.messages.set_flash(Message(request, 'users/passwords/reset_done', extra={'user':user}), 'success')
  71. user.email_user(
  72. request,
  73. 'users/reset_new',
  74. _("Your New Password"),
  75. {'password': new_password}
  76. )
  77. return redirect(reverse('sign_in'))
  78. except User.DoesNotExist:
  79. return error404(request)