utg-base 1.19.0__py3-none-any.whl → 1.20.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/utils.py +5 -2
- utg_base/utils/__init__.py +1 -1
- utg_base/utils/data.py +6 -0
- {utg_base-1.19.0.dist-info → utg_base-1.20.0.dist-info}/METADATA +1 -1
- {utg_base-1.19.0.dist-info → utg_base-1.20.0.dist-info}/RECORD +6 -6
- {utg_base-1.19.0.dist-info → utg_base-1.20.0.dist-info}/WHEEL +0 -0
utg_base/permissions/utils.py
CHANGED
|
@@ -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)
|
|
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)
|
|
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]
|
utg_base/utils/__init__.py
CHANGED
utg_base/utils/data.py
CHANGED
|
@@ -147,3 +147,9 @@ def safe_get(obj, dotted_path: str, default=None):
|
|
|
147
147
|
return default
|
|
148
148
|
|
|
149
149
|
return obj
|
|
150
|
+
|
|
151
|
+
|
|
152
|
+
def compute_change_percent(current, previous, ndigits=2):
|
|
153
|
+
if not current or previous in (None, 0):
|
|
154
|
+
return None
|
|
155
|
+
return round(((current - previous) / previous) * 100, ndigits)
|
|
@@ -42,7 +42,7 @@ utg_base/models/timestamp.py,sha256=AkCliNXnvs8Z17b1mcS7gOK7v6h3Jul6WCyGyVAkb-w,
|
|
|
42
42
|
utg_base/permissions/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
43
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=
|
|
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
|
|
@@ -59,8 +59,8 @@ utg_base/u_services/migrations/0001_initial.py,sha256=UtUtk2r2uEuQiYIRZb0Of6sbsT
|
|
|
59
59
|
utg_base/u_services/migrations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
60
60
|
utg_base/u_services/models.py,sha256=seaxBj9vNWrPu1Y8r7NzHEuXemtSvqLkaw4S1Xgr58I,1310
|
|
61
61
|
utg_base/u_services/u_requests.py,sha256=fGNWWQ3RJOOARgNHkScsqlGXwP6sI-HnS3Y-HnSoVS4,1709
|
|
62
|
-
utg_base/utils/__init__.py,sha256=
|
|
63
|
-
utg_base/utils/data.py,sha256=
|
|
62
|
+
utg_base/utils/__init__.py,sha256=zRTdSLGpukInlb7oRD6vcI1jKQkkBR3jTCiOiwOmRyA,159
|
|
63
|
+
utg_base/utils/data.py,sha256=0_upHGaiafuZOCHaL7IT84b0E0qknCA4pHPQMFH8cdY,4135
|
|
64
64
|
utg_base/utils/date.py,sha256=thcbK6RgTUYZfs4_vW5ucuu2e8H0rei6tv7SEC72iwM,3612
|
|
65
65
|
utg_base/utils/dict_util.py,sha256=ipdCZO8aTukGQ319OWHb2Ij5MNtV-FioJQ4qCX3Th48,758
|
|
66
66
|
utg_base/utils/response_processors.py,sha256=WdZQL49wOJqCIY2MucAI6sez_llCqih0v_ltQa-mv7k,687
|
|
@@ -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.
|
|
73
|
-
utg_base-1.
|
|
74
|
-
utg_base-1.
|
|
72
|
+
utg_base-1.20.0.dist-info/METADATA,sha256=hEV7vSsLKxTXrNiUqiPqS2orAqIEUpxFONpkbVxcZlc,960
|
|
73
|
+
utg_base-1.20.0.dist-info/WHEEL,sha256=Nq82e9rUAnEjt98J6MlVmMCZb-t9cYE2Ir1kpBmnWfs,88
|
|
74
|
+
utg_base-1.20.0.dist-info/RECORD,,
|
|
File without changes
|