options.py 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. from django.contrib.auth import update_session_auth_hash
  2. from django.core.urlresolvers import reverse
  3. from django.db import IntegrityError
  4. from django.shortcuts import render
  5. from django.utils.translation import ugettext as _
  6. from misago.users.credentialchange import read_new_credential
  7. from misago.users.decorators import deny_guests
  8. from misago.users.pages import usercp
  9. @deny_guests
  10. def index(request, *args, **kwargs):
  11. user_options = []
  12. for section in usercp.get_sections(request):
  13. user_options.append({
  14. 'name': unicode(section['name']),
  15. 'icon': section['icon'],
  16. 'component': section['component'],
  17. })
  18. request.frontend_context.update({
  19. 'USER_OPTIONS': user_options
  20. });
  21. return render(request, 'misago/options/noscript.html')
  22. class ChangeError(Exception):
  23. pass
  24. def confirm_change_view(f):
  25. @deny_guests
  26. def decorator(request, token):
  27. try:
  28. return f(request, token)
  29. except ChangeError as e:
  30. return render(request, 'misago/options/credentials_error.html',
  31. status=400)
  32. return decorator
  33. @confirm_change_view
  34. def confirm_email_change(request, token):
  35. new_credential = read_new_credential(request, 'email', token)
  36. if not new_credential:
  37. raise ChangeError()
  38. try:
  39. request.user.set_email(new_credential)
  40. request.user.save(update_fields=['email', 'email_hash'])
  41. except IntegrityError:
  42. raise ChangeError()
  43. message = _("%(user)s, your e-mail has been changed.")
  44. return render(request, 'misago/options/credentials_changed.html', {
  45. 'message': message % {'user': request.user.username},
  46. })
  47. @confirm_change_view
  48. def confirm_password_change(request, token):
  49. new_credential = read_new_credential(request, 'password', token)
  50. if not new_credential:
  51. raise ChangeError()
  52. request.user.set_password(new_credential)
  53. update_session_auth_hash(request, request.user)
  54. request.user.save(update_fields=['password'])
  55. message = _("%(user)s, your password has been changed.")
  56. return render(request, 'misago/options/credentials_changed.html', {
  57. 'message': message % {'user': request.user.username},
  58. })