__init__.py 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. from django.urls import reverse, NoReverseMatch
  2. from django.shortcuts import render as dj_render
  3. from ...conf import settings
  4. from .. import site
  5. from ..auth import is_admin_authorized, update_admin_authorization
  6. from .auth import login
  7. def get_protected_namespace(request):
  8. for namespace in settings.MISAGO_ADMIN_NAMESPACES:
  9. try:
  10. admin_path = reverse("%s:index" % namespace)
  11. if request.path.startswith(admin_path):
  12. return namespace
  13. except NoReverseMatch:
  14. pass
  15. def render(request, template, context=None, error_page=False):
  16. context = context or {}
  17. navigation = site.visible_branches(request)
  18. sections = navigation[0]
  19. try:
  20. actions = navigation[1]
  21. except IndexError:
  22. actions = []
  23. try:
  24. pages = navigation[2]
  25. except IndexError:
  26. pages = []
  27. context.update({"sections": sections, "actions": actions, "pages": pages})
  28. if error_page:
  29. # admittedly haxy solution for displaying navs on error pages
  30. context["actions"] = []
  31. context["pages"] = []
  32. for item in navigation[0]:
  33. item["is_active"] = False
  34. else:
  35. context["active_link"] = None
  36. for item in navigation[-1]:
  37. if item["is_active"]:
  38. context["active_link"] = item
  39. break
  40. return dj_render(request, template, context)
  41. # Decorator for views
  42. def protected_admin_view(f):
  43. def decorator(request, *args, **kwargs):
  44. protected_view = get_protected_namespace(request)
  45. if protected_view:
  46. if is_admin_authorized(request):
  47. update_admin_authorization(request)
  48. return f(request, *args, **kwargs)
  49. request.admin_namespace = protected_view
  50. return login(request)
  51. return f(request, *args, **kwargs)
  52. return decorator