From 33a8666653ab0fd22a053b9dbd401fca12422948 Mon Sep 17 00:00:00 2001 From: Ben White Date: Tue, 26 Mar 2024 08:43:31 +0100 Subject: [PATCH] Cache DB lookup calls --- posthog/rbac/user_access_control.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/posthog/rbac/user_access_control.py b/posthog/rbac/user_access_control.py index b342f4bcc2736..0de31aef4ac58 100644 --- a/posthog/rbac/user_access_control.py +++ b/posthog/rbac/user_access_control.py @@ -1,4 +1,4 @@ -from functools import cached_property +from functools import cached_property, cache from django.db.models import Model, Q, QuerySet from rest_framework import serializers from typing import TYPE_CHECKING, List, Optional, cast @@ -96,7 +96,7 @@ def access_controls_supported(self) -> bool: AvailableFeature.PROJECT_BASED_PERMISSIONING ) or self._organization.is_feature_available(AvailableFeature.ADVANCED_PERMISSIONS) - # @cached_property + @cache def _access_controls_for_object(self, obj: Model, resource: str) -> List[_AccessControl]: """ Used when checking an individual object - gets all access controls for the object and its type @@ -124,7 +124,7 @@ def _access_controls_for_object(self, obj: Model, resource: str) -> List[_Access ) ) - # @cached_property + @cache def _access_controls_for_resource(self, resource: APIScopeObject) -> List[_AccessControl]: """ Used when checking an individual object - gets all access controls for the object and its type