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.
@@ -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)
@@ -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(f'user:{user_id}:permissions', perm))
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(f'user:{user_id}:permissions', perms)
30
+ result = redis_conn.smismember(generate_perm_cache_key(user_id), perms)
31
31
 
32
32
  if operator == "OR":
33
33
  return any(result)
@@ -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
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: utg-base
3
- Version: 1.14.0
3
+ Version: 1.15.0
4
4
  Summary: UTG Base Package
5
5
  Author: Olimboy
6
6
  Author-email: shavkatov.olimboy@mail.ru
@@ -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/utils.py,sha256=zgwyp6r-CySPrUFCZ1qm8_4UzsbtMYPlgzyCBpOQ4BU,2585
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=ndbeLXqLMUyCqqs_xqEFOCaE1rYnLxxI-LMeQx2YsjY,5903
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.14.0.dist-info/METADATA,sha256=iXWdpkKrzStHPqX6amNh9A2mXU-F9xZRnHynmSUte1k,917
71
- utg_base-1.14.0.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
72
- utg_base-1.14.0.dist-info/RECORD,,
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,,