utg-base 1.18.0__py3-none-any.whl → 1.19.1__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.
@@ -19,7 +19,7 @@ def has_perm(*permission: str, operator: Literal["OR", "AND"] = "OR"):
19
19
  @wraps(view_func)
20
20
  def _wrapped_view(self, request, *args, **kwargs):
21
21
  if not has_permissions(user_id=request.user.id, perms=list(permission), operator=operator, request=request):
22
- raise PermissionDenied
22
+ self.permission_denied(request)
23
23
  return view_func(self, request, *args, **kwargs)
24
24
  return _wrapped_view
25
25
  return decorator
@@ -55,7 +55,7 @@ def has_class_perm(permissions_map: Dict[str, Union[str, List[str]]], operator:
55
55
  required_perms = [required_perms]
56
56
 
57
57
  if not has_permissions(user_id=request.user.id, perms=required_perms, operator=operator, request=request):
58
- raise PermissionDenied
58
+ self.permission_denied(request)
59
59
 
60
60
  return original_initial(self, request, *args, **kwargs)
61
61
 
@@ -7,6 +7,7 @@ from django_redis import get_redis_connection
7
7
  from redis.client import Redis
8
8
  from rest_framework.request import Request
9
9
 
10
+ from utg_base.constants import AccessibilityType
10
11
  from utg_base.env import env
11
12
  from utg_base.u_services import u_requests
12
13
  from utg_base.u_services.constants import UServices
@@ -19,7 +20,8 @@ def generate_perm_cache_key(user_id: str):
19
20
 
20
21
 
21
22
  def has_perm(user_id, perm, request=None):
22
- if request is not None and isinstance(request, Request) and request.user.is_superuser:
23
+ if (request is not None and isinstance(request, Request)
24
+ and (request.user.is_superuser or request.user.accessibility == AccessibilityType.ADMIN)):
23
25
  return True
24
26
  redis_conn: Redis = get_redis_connection("shared")
25
27
  perm = f"{to_snake_case(env('APP_NAME'))}:{perm}"
@@ -27,7 +29,8 @@ def has_perm(user_id, perm, request=None):
27
29
 
28
30
 
29
31
  def has_perms(user_id: str, perms: list[str], operator: Literal["OR", "AND"] = "OR", request=None):
30
- if request is not None and isinstance(request, Request) and request.user.is_superuser:
32
+ if (request is not None and isinstance(request, Request)
33
+ and (request.user.is_superuser or request.user.accessibility == AccessibilityType.ADMIN)):
31
34
  return True
32
35
  redis_conn: Redis = get_redis_connection("shared")
33
36
  perms = [f"{to_snake_case(env('APP_NAME'))}:{perm}" for perm in perms]
@@ -38,6 +41,12 @@ def has_perms(user_id: str, perms: list[str], operator: Literal["OR", "AND"] = "
38
41
  return all(result)
39
42
 
40
43
 
44
+ def get_user_perms(user_id: str):
45
+ redis_conn: Redis = get_redis_connection("shared")
46
+ perms = redis_conn.smembers(generate_perm_cache_key(user_id))
47
+ return [perm.decode() for perm in perms]
48
+
49
+
41
50
  def get_permissions(url_patterns):
42
51
  permissions = set()
43
52
 
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: utg-base
3
- Version: 1.18.0
3
+ Version: 1.19.1
4
4
  Summary: UTG Base Package
5
5
  Author: Olimboy
6
6
  Author-email: shavkatov.olimboy@mail.ru
@@ -40,9 +40,9 @@ utg_base/models/__init__.py,sha256=1zXygGICiR3iUCKdkNal9d3i3kNp654gFgBf_VlR2gI,6
40
40
  utg_base/models/jwt_user.py,sha256=6TQ5wB_OZBtGhRL-2MonBGZm0n0Y86s4BRTxiRlUJOk,375
41
41
  utg_base/models/timestamp.py,sha256=AkCliNXnvs8Z17b1mcS7gOK7v6h3Jul6WCyGyVAkb-w,217
42
42
  utg_base/permissions/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
43
- utg_base/permissions/decorators.py,sha256=chjOUOQAF0qbedDtOebGzp1HUeyhFLlt9fnWmnsg6u0,2100
43
+ utg_base/permissions/decorators.py,sha256=g-ozzjkjJ-O69_wHWzZnZ9jitFR6MxqGLz2skFjzht4,2118
44
44
  utg_base/permissions/folder.py,sha256=uJv40FVb7R379qss66a5oUcLK7KCUIL6DPbzEcGOw38,694
45
- utg_base/permissions/utils.py,sha256=Jhm3RIe9Pcm5eZIHrRMiHo8jv7py5Xl3GGNOBumKl6k,2841
45
+ utg_base/permissions/utils.py,sha256=ZoPlqVRmAQv8IS7AYWN1uEWj0CjTt_y5gy7A5hz2His,3238
46
46
  utg_base/references_api/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
47
47
  utg_base/references_api/apps.py,sha256=thAGmO-ZT-OD9dHHBSQRL_RRt-Es_jt-mEmHgVTpERs,168
48
48
  utg_base/references_api/migrations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
@@ -69,6 +69,6 @@ utg_base/utils/sql.py,sha256=rqIWcSjdjIMszdRnsnhV5TTYB8W17RPOujIQA9rKC_Y,762
69
69
  utg_base/utils/string.py,sha256=ATwIo9uLa00p85h_NjRYLcjRs8o3KSGF7s2yhTg5GiA,1073
70
70
  utg_base/utils/thread.py,sha256=4RqRnwtyHymY-dNcuPrMSTamE2V7wCMVfzzyIb0P4TI,2191
71
71
  utg_base/utils/translation.py,sha256=GxJHUt0iar_0E7RWBPbeLFQ4DhgXBjffHCmxfKyjFtk,463
72
- utg_base-1.18.0.dist-info/METADATA,sha256=UfKeX0kty8_sO1vvemCJkWSnRMLwF1eP67hLuz5KZIo,960
73
- utg_base-1.18.0.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
74
- utg_base-1.18.0.dist-info/RECORD,,
72
+ utg_base-1.19.1.dist-info/METADATA,sha256=xgijhSRbBO6e5wcVUngfQLkNpB6-64mxZIcc9Q906OU,960
73
+ utg_base-1.19.1.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
74
+ utg_base-1.19.1.dist-info/RECORD,,