diff --git a/aleksis/apps/alsijil/util/predicates.py b/aleksis/apps/alsijil/util/predicates.py index 43889191baecaf3e196c0b776c869cf70bc40d4c..99217a5a8dd9c881a4cd0816ae515683044b0dba 100644 --- a/aleksis/apps/alsijil/util/predicates.py +++ b/aleksis/apps/alsijil/util/predicates.py @@ -151,13 +151,13 @@ def has_lesson_group_object_perm(perm: str): """ name = f"has_lesson_group_object_perm:{perm}" - ct = get_content_type_by_perm(perm) - permissions = Permission.objects.filter(content_type=ct, codename=perm) @predicate(name) def fn(user: User, obj: LessonPeriod) -> bool: if hasattr(obj, "lesson"): groups = obj.lesson.groups.all() + ct = get_content_type_by_perm(perm) + permissions = Permission.objects.filter(content_type=ct, codename=perm) qs = UserObjectPermission.objects.filter( object_pk__in=list(groups.values_list("pk", flat=True)), content_type=ct, @@ -177,12 +177,12 @@ def has_personal_note_group_perm(perm: str): """ name = f"has_personal_note_person_or_group_perm:{perm}" - ct = get_content_type_by_perm(perm) - permissions = Permission.objects.filter(content_type=ct, codename=perm) @predicate(name) def fn(user: User, obj: PersonalNote) -> bool: if hasattr(obj, "person"): + ct = get_content_type_by_perm(perm) + permissions = Permission.objects.filter(content_type=ct, codename=perm) groups = obj.person.member_of.all() qs = UserObjectPermission.objects.filter( object_pk__in=list(groups.values_list("pk", flat=True)),