activation.py 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  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. return f(request, *args, **kwargs)
  16. return decorator
  17. @activation_view
  18. def request_activation(request):
  19. request.frontend_context.update(
  20. {"SEND_ACTIVATION_API": reverse("misago:api:send-activation")}
  21. )
  22. return render(request, "misago/activation/request.html")
  23. class ActivationStopped(Exception):
  24. pass
  25. class ActivationError(Exception):
  26. pass
  27. @activation_view
  28. def activate_by_token(request, pk, token):
  29. inactive_user = get_object_or_404(User, pk=pk, is_active=True)
  30. try:
  31. if not inactive_user.requires_activation:
  32. message = _("%(user)s, your account is already active.")
  33. raise ActivationStopped(message % {"user": inactive_user.username})
  34. if not is_activation_token_valid(inactive_user, token):
  35. message = _(
  36. "%(user)s, your activation link is invalid. "
  37. "Try again or request new activation link."
  38. )
  39. raise ActivationError(message % {"user": inactive_user.username})
  40. ban = get_user_ban(inactive_user, request.cache_versions)
  41. if ban:
  42. raise Banned(ban)
  43. except ActivationStopped as e:
  44. return render(request, "misago/activation/stopped.html", {"message": e.args[0]})
  45. except ActivationError as e:
  46. return render(
  47. request, "misago/activation/error.html", {"message": e.args[0]}, status=400
  48. )
  49. inactive_user.requires_activation = User.ACTIVATION_NONE
  50. inactive_user.save(update_fields=["requires_activation"])
  51. message = _("%(user)s, your account has been activated!")
  52. return render(
  53. request,
  54. "misago/activation/done.html",
  55. {"message": message % {"user": inactive_user.username}},
  56. )