rb-commons 0.4.3__tar.gz → 0.4.4__tar.gz
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.
- {rb_commons-0.4.3 → rb_commons-0.4.4}/PKG-INFO +1 -1
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/orm/managers.py +26 -22
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons.egg-info/PKG-INFO +1 -1
- {rb_commons-0.4.3 → rb_commons-0.4.4}/setup.py +1 -1
- {rb_commons-0.4.3 → rb_commons-0.4.4}/README.md +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/broker/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/broker/consumer.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/configs/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/configs/config.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/configs/injections.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/configs/rabbitmq.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/http/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/http/base_api.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/http/consul.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/http/exceptions.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/orm/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/orm/exceptions.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/orm/services.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/permissions/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/permissions/role_permissions.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/schemes/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/schemes/jwt.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/utils/__init__.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons/utils/media.py +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons.egg-info/SOURCES.txt +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons.egg-info/dependency_links.txt +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons.egg-info/requires.txt +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/rb_commons.egg-info/top_level.txt +0 -0
- {rb_commons-0.4.3 → rb_commons-0.4.4}/setup.cfg +0 -0
@@ -65,22 +65,29 @@ class BaseManager(Generic[ModelType]):
|
|
65
65
|
return instance
|
66
66
|
|
67
67
|
def _apply_eager_loading(self, stmt, load_all_relations: bool = False):
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
mapper
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
68
|
+
if not load_all_relations:
|
69
|
+
return stmt
|
70
|
+
|
71
|
+
opts = []
|
72
|
+
visited = set()
|
73
|
+
|
74
|
+
def recurse(model, loader=None):
|
75
|
+
mapper = inspect(model)
|
76
|
+
if mapper in visited:
|
77
|
+
return
|
78
|
+
visited.add(mapper)
|
79
|
+
|
80
|
+
for rel in mapper.relationships:
|
81
|
+
attr = getattr(model, rel.key)
|
82
|
+
if loader is None:
|
83
|
+
this_loader = selectinload(attr)
|
84
|
+
else:
|
85
|
+
this_loader = loader.selectinload(attr)
|
86
|
+
opts.append(this_loader)
|
87
|
+
recurse(rel.mapper.class_, this_loader)
|
82
88
|
|
83
|
-
|
89
|
+
recurse(self.model)
|
90
|
+
return stmt.options(*opts)
|
84
91
|
|
85
92
|
def filter(self, **kwargs) -> 'BaseManager[ModelType]':
|
86
93
|
"""
|
@@ -162,16 +169,13 @@ class BaseManager(Generic[ModelType]):
|
|
162
169
|
async def all(self, load_all_relations: bool = False) -> List[ModelType]:
|
163
170
|
self._ensure_filtered()
|
164
171
|
|
165
|
-
|
166
|
-
|
172
|
+
stmt = select(self.model).filter(and_(*self.filters))
|
173
|
+
stmt = self._apply_eager_loading(stmt, load_all_relations)
|
167
174
|
|
168
|
-
result = await self.session.execute(
|
175
|
+
result = await self.session.execute(stmt)
|
169
176
|
rows = result.scalars().all()
|
170
177
|
|
171
|
-
unique_by_pk = {}
|
172
|
-
for obj in rows:
|
173
|
-
unique_by_pk[obj.id] = obj
|
174
|
-
|
178
|
+
unique_by_pk = {obj.id: obj for obj in rows}
|
175
179
|
return list(unique_by_pk.values())
|
176
180
|
|
177
181
|
async def first(self, load_relations: Sequence[str] = None) -> Optional[ModelType]:
|
@@ -5,7 +5,7 @@ with open("README.md", "r", encoding="utf-8") as fh:
|
|
5
5
|
|
6
6
|
setup(
|
7
7
|
name="rb-commons",
|
8
|
-
version="0.4.
|
8
|
+
version="0.4.4",
|
9
9
|
author="Abdulvoris",
|
10
10
|
author_email="erkinovabdulvoris101@gmail.com",
|
11
11
|
description="Commons of project and simplified orm based on sqlalchemy.",
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|