activation.py 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. from django.core.exceptions import PermissionDenied
  2. from django.contrib.auth import get_user_model
  3. from django.shortcuts import get_object_or_404, render
  4. from django.urls import reverse
  5. from django.utils.translation import gettext as _
  6. from ...core.exceptions import Banned
  7. from ..bans import get_user_ban
  8. from ..decorators import deny_authenticated, deny_banned_ips
  9. from ..tokens import is_activation_token_valid
  10. User = get_user_model()
  11. def activation_view(f):
  12. @deny_authenticated
  13. @deny_banned_ips
  14. def decorator(request, *args, **kwargs):
  15. if request.settings.enable_sso:
  16. raise PermissionDenied(
  17. _("Please use the 3rd party site to activate your account.")
  18. )
  19. return f(request, *args, **kwargs)
  20. return decorator
  21. @activation_view
  22. def request_activation(request):
  23. request.frontend_context.update(
  24. {"SEND_ACTIVATION_API": reverse("misago:api:send-activation")}
  25. )
  26. return render(request, "misago/activation/request.html")
  27. class ActivationStopped(Exception):
  28. pass
  29. class ActivationError(Exception):
  30. pass
  31. @activation_view
  32. def activate_by_token(request, pk, token):
  33. inactive_user = get_object_or_404(User, pk=pk, is_active=True)
  34. try:
  35. if not inactive_user.requires_activation:
  36. message = _("%(user)s, your account is already active.")
  37. raise ActivationStopped(message % {"user": inactive_user.username})
  38. if not is_activation_token_valid(inactive_user, token):
  39. message = _(
  40. "%(user)s, your activation link is invalid. "
  41. "Try again or request new activation link."
  42. )
  43. raise ActivationError(message % {"user": inactive_user.username})
  44. ban = get_user_ban(inactive_user, request.cache_versions)
  45. if ban:
  46. raise Banned(ban)
  47. except ActivationStopped as e:
  48. return render(request, "misago/activation/stopped.html", {"message": e.args[0]})
  49. except ActivationError as e:
  50. return render(
  51. request, "misago/activation/error.html", {"message": e.args[0]}, status=400
  52. )
  53. inactive_user.requires_activation = User.ACTIVATION_NONE
  54. inactive_user.save(update_fields=["requires_activation"])
  55. message = _("%(user)s, your account has been activated!")
  56. return render(
  57. request,
  58. "misago/activation/done.html",
  59. {"message": message % {"user": inactive_user.username}},
  60. )