rb-commons 0.2.9__tar.gz → 0.3.1__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.2.9 → rb_commons-0.3.1}/PKG-INFO +1 -1
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/http/consul.py +2 -2
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/orm/managers.py +33 -9
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons.egg-info/PKG-INFO +1 -1
- {rb_commons-0.2.9 → rb_commons-0.3.1}/setup.py +1 -1
- {rb_commons-0.2.9 → rb_commons-0.3.1}/README.md +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/broker/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/broker/consumer.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/configs/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/configs/config.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/configs/injections.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/configs/rabbitmq.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/http/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/http/base_api.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/http/exceptions.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/orm/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/orm/exceptions.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/permissions/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/permissions/role_permissions.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/schemes/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/schemes/jwt.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/utils/__init__.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons/utils/media.py +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons.egg-info/SOURCES.txt +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons.egg-info/dependency_links.txt +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons.egg-info/requires.txt +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/rb_commons.egg-info/top_level.txt +0 -0
- {rb_commons-0.2.9 → rb_commons-0.3.1}/setup.cfg +0 -0
@@ -5,8 +5,8 @@ from rb_commons.configs.config import configs
|
|
5
5
|
|
6
6
|
|
7
7
|
class ServiceDiscovery:
|
8
|
-
def __init__(self) -> None:
|
9
|
-
self.consul_client = consul.Consul(host=
|
8
|
+
def __init__(self, host: str, port: int) -> None:
|
9
|
+
self.consul_client = consul.Consul(host=host, port=port)
|
10
10
|
self.cache = aiocache.Cache(aiocache.SimpleMemoryCache)
|
11
11
|
|
12
12
|
async def _get_service_instances(self, service_name: str) -> dict:
|
@@ -1,9 +1,9 @@
|
|
1
1
|
import uuid
|
2
|
-
from typing import TypeVar, Type, Generic, Optional, List, Dict, Literal, Union
|
3
|
-
from sqlalchemy import select, delete, update, and_, func
|
2
|
+
from typing import TypeVar, Type, Generic, Optional, List, Dict, Literal, Union, Sequence
|
3
|
+
from sqlalchemy import select, delete, update, and_, func, desc
|
4
4
|
from sqlalchemy.exc import IntegrityError, SQLAlchemyError, NoResultFound
|
5
5
|
from sqlalchemy.ext.asyncio import AsyncSession
|
6
|
-
from sqlalchemy.orm import declarative_base, InstrumentedAttribute
|
6
|
+
from sqlalchemy.orm import declarative_base, InstrumentedAttribute, selectinload
|
7
7
|
|
8
8
|
from rb_commons.http.exceptions import NotFoundException
|
9
9
|
from rb_commons.orm.exceptions import DatabaseException, InternalException
|
@@ -47,12 +47,17 @@ class BaseManager(Generic[ModelType]):
|
|
47
47
|
await self.session.refresh(instance)
|
48
48
|
return instance
|
49
49
|
|
50
|
-
async def get(self, pk: Union[str, int, uuid.UUID]) -> Optional[ModelType]:
|
50
|
+
async def get(self, pk: Union[str, int, uuid.UUID], load_relations: Sequence[str] = None) -> Optional[ModelType]:
|
51
51
|
"""
|
52
52
|
get object based on conditions
|
53
53
|
"""
|
54
|
-
|
55
|
-
|
54
|
+
stmt = select(self.model).filter_by(id=pk)
|
55
|
+
|
56
|
+
if load_relations:
|
57
|
+
for rel in load_relations:
|
58
|
+
stmt = stmt.options(selectinload(getattr(self.model, rel)))
|
59
|
+
|
60
|
+
result = await self.session.execute(stmt)
|
56
61
|
instance = result.scalar_one_or_none()
|
57
62
|
|
58
63
|
if instance is None:
|
@@ -129,12 +134,31 @@ class BaseManager(Generic[ModelType]):
|
|
129
134
|
result = await self.session.execute(query)
|
130
135
|
return list(result.scalars().all())
|
131
136
|
|
132
|
-
async def first(self) -> Optional[ModelType]:
|
137
|
+
async def first(self, load_relations: Sequence[str] = None) -> Optional[ModelType]:
|
133
138
|
"""Return the first matching object, or None."""
|
134
139
|
self._ensure_filtered()
|
135
140
|
|
136
|
-
|
137
|
-
|
141
|
+
stmt = select(self.model).filter(and_(*self.filters))
|
142
|
+
|
143
|
+
if load_relations:
|
144
|
+
for rel in load_relations:
|
145
|
+
stmt = stmt.options(selectinload(getattr(self.model, rel)))
|
146
|
+
|
147
|
+
result = await self.session.execute(stmt)
|
148
|
+
return result.scalars().first()
|
149
|
+
|
150
|
+
async def last(self, load_relations: Sequence[str] = None) -> Optional[ModelType]:
|
151
|
+
"""Return the last matching object, or None."""
|
152
|
+
|
153
|
+
self._ensure_filtered()
|
154
|
+
|
155
|
+
stmt = select(self.model).filter(and_(*self.filters)).order_by(desc(self.model.id))
|
156
|
+
|
157
|
+
if load_relations:
|
158
|
+
for rel in load_relations:
|
159
|
+
stmt = stmt.options(selectinload(getattr(self.model, rel)))
|
160
|
+
|
161
|
+
result = await self.session.execute(stmt)
|
138
162
|
return result.scalars().first()
|
139
163
|
|
140
164
|
async def count(self) -> int:
|
@@ -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.
|
8
|
+
version="0.3.1",
|
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
|