utg-base 1.14.0__py3-none-any.whl → 1.15.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- utg_base/permissions/folder.py +22 -0
- utg_base/permissions/utils.py +2 -2
- utg_base/references_api/utils.py +6 -1
- {utg_base-1.14.0.dist-info → utg_base-1.15.0.dist-info}/METADATA +1 -1
- {utg_base-1.14.0.dist-info → utg_base-1.15.0.dist-info}/RECORD +6 -5
- {utg_base-1.14.0.dist-info → utg_base-1.15.0.dist-info}/WHEEL +0 -0
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
from typing import Literal
|
|
2
|
+
|
|
3
|
+
from django_redis import get_redis_connection
|
|
4
|
+
from redis.client import Redis
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
def generate_folder_cache_key(user_id: str):
|
|
8
|
+
return f"user:{user_id}:folders"
|
|
9
|
+
|
|
10
|
+
|
|
11
|
+
def has_folder_perm(user_id, folder_perm):
|
|
12
|
+
redis_conn: Redis = get_redis_connection("shared")
|
|
13
|
+
return bool(redis_conn.sismember(generate_folder_cache_key(user_id), folder_perm))
|
|
14
|
+
|
|
15
|
+
|
|
16
|
+
def has_folder_perms(user_id: str, folder_perms: list[str], operator: Literal["OR", "AND"] = "OR"):
|
|
17
|
+
redis_conn: Redis = get_redis_connection("shared")
|
|
18
|
+
result = redis_conn.smismember(generate_folder_cache_key(user_id), folder_perms)
|
|
19
|
+
|
|
20
|
+
if operator == "OR":
|
|
21
|
+
return any(result)
|
|
22
|
+
return all(result)
|
utg_base/permissions/utils.py
CHANGED
|
@@ -21,13 +21,13 @@ def generate_perm_cache_key(user_id: str):
|
|
|
21
21
|
def has_perm(user_id, perm):
|
|
22
22
|
redis_conn: Redis = get_redis_connection("shared")
|
|
23
23
|
perm = f"{to_snake_case(env('APP_NAME'))}:{perm}"
|
|
24
|
-
return bool(redis_conn.sismember(
|
|
24
|
+
return bool(redis_conn.sismember(generate_perm_cache_key(user_id), perm))
|
|
25
25
|
|
|
26
26
|
|
|
27
27
|
def has_perms(user_id: str, perms: list[str], operator: Literal["OR", "AND"] = "OR"):
|
|
28
28
|
redis_conn: Redis = get_redis_connection("shared")
|
|
29
29
|
perms = [f"{to_snake_case(env('APP_NAME'))}:{perm}" for perm in perms]
|
|
30
|
-
result = redis_conn.smismember(
|
|
30
|
+
result = redis_conn.smismember(generate_perm_cache_key(user_id), perms)
|
|
31
31
|
|
|
32
32
|
if operator == "OR":
|
|
33
33
|
return any(result)
|
utg_base/references_api/utils.py
CHANGED
|
@@ -8,6 +8,7 @@ from drf_spectacular.utils import extend_schema, extend_schema_serializer
|
|
|
8
8
|
from rest_framework import filters
|
|
9
9
|
from rest_framework import viewsets, serializers
|
|
10
10
|
|
|
11
|
+
from utg_base.api.base import BaseAPIView
|
|
11
12
|
from utg_base.permissions.decorators import has_class_perm
|
|
12
13
|
|
|
13
14
|
serializer_classes = {}
|
|
@@ -82,7 +83,7 @@ def create_view_set(model: Model):
|
|
|
82
83
|
fields_list = get_model_fields_list(model)
|
|
83
84
|
|
|
84
85
|
@extend_schema(tags=[get_url_prefix(model)])
|
|
85
|
-
class ViewSet(viewsets.ModelViewSet):
|
|
86
|
+
class ViewSet(viewsets.ModelViewSet, BaseAPIView):
|
|
86
87
|
http_method_names = get_api_meta_property(model, 'http_method_names') or ['get', 'patch']
|
|
87
88
|
manager = model.objects.order_by(*get_ordering(model))
|
|
88
89
|
filter_backends = [filters.SearchFilter]
|
|
@@ -98,6 +99,10 @@ def create_view_set(model: Model):
|
|
|
98
99
|
|
|
99
100
|
return create_serializer(model)
|
|
100
101
|
|
|
102
|
+
def get_queryset(self):
|
|
103
|
+
self.update_lang()
|
|
104
|
+
return self.manager.all()
|
|
105
|
+
|
|
101
106
|
if permissions := get_api_meta_property(model, 'permissions'):
|
|
102
107
|
has_class_perm(permissions)(ViewSet)
|
|
103
108
|
|
|
@@ -40,12 +40,13 @@ utg_base/models/jwt_user.py,sha256=6TQ5wB_OZBtGhRL-2MonBGZm0n0Y86s4BRTxiRlUJOk,3
|
|
|
40
40
|
utg_base/models/timestamp.py,sha256=AkCliNXnvs8Z17b1mcS7gOK7v6h3Jul6WCyGyVAkb-w,217
|
|
41
41
|
utg_base/permissions/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
42
42
|
utg_base/permissions/decorators.py,sha256=bDmC_fUuOIo-Lp92wO4B3q5XtwhC4uU4n3NamDft4vI,2066
|
|
43
|
-
utg_base/permissions/
|
|
43
|
+
utg_base/permissions/folder.py,sha256=uJv40FVb7R379qss66a5oUcLK7KCUIL6DPbzEcGOw38,694
|
|
44
|
+
utg_base/permissions/utils.py,sha256=8nbs9PwWEtInFv8wRDMre1pAPu_FwmVz7A07i_WikU8,2591
|
|
44
45
|
utg_base/references_api/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
45
46
|
utg_base/references_api/apps.py,sha256=thAGmO-ZT-OD9dHHBSQRL_RRt-Es_jt-mEmHgVTpERs,168
|
|
46
47
|
utg_base/references_api/migrations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
47
48
|
utg_base/references_api/urls.py,sha256=WkLACQ8GfK5pJkvt8FuYdOxcqSZHj7pYRw51M9WluGw,390
|
|
48
|
-
utg_base/references_api/utils.py,sha256=
|
|
49
|
+
utg_base/references_api/utils.py,sha256=m9Jl9ccJylqhjlP6UdBZyx3Difag3viV9QWmBGu7ubY,6060
|
|
49
50
|
utg_base/services/__init__.py,sha256=LqtwUiqEZPIbKRGJfve5D5m3ucV6Kw1Nbo5Jnj_hPhY,37
|
|
50
51
|
utg_base/services/base_api.py,sha256=bMTmjy8TRN4WTCgV_1RvkquoqijJQ1hP7BBtPgW_AH0,5677
|
|
51
52
|
utg_base/signals/__init__.py,sha256=5SKumqAQrfrXUzi4NO3zjPAXV2TG3EDKxOomaF-e15M,35
|
|
@@ -67,6 +68,6 @@ utg_base/utils/sql.py,sha256=rqIWcSjdjIMszdRnsnhV5TTYB8W17RPOujIQA9rKC_Y,762
|
|
|
67
68
|
utg_base/utils/string.py,sha256=ATwIo9uLa00p85h_NjRYLcjRs8o3KSGF7s2yhTg5GiA,1073
|
|
68
69
|
utg_base/utils/thread.py,sha256=4RqRnwtyHymY-dNcuPrMSTamE2V7wCMVfzzyIb0P4TI,2191
|
|
69
70
|
utg_base/utils/translation.py,sha256=GxJHUt0iar_0E7RWBPbeLFQ4DhgXBjffHCmxfKyjFtk,463
|
|
70
|
-
utg_base-1.
|
|
71
|
-
utg_base-1.
|
|
72
|
-
utg_base-1.
|
|
71
|
+
utg_base-1.15.0.dist-info/METADATA,sha256=1ltxZeXg6sjr09qwXTbJivshbgsYh42Dy2yVuyoK8GE,917
|
|
72
|
+
utg_base-1.15.0.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
|
|
73
|
+
utg_base-1.15.0.dist-info/RECORD,,
|
|
File without changes
|