rb-commons 0.5.8__tar.gz → 0.5.9__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.5.8 → rb_commons-0.5.9}/PKG-INFO +1 -1
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/orm/managers.py +20 -1
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons.egg-info/PKG-INFO +1 -1
- {rb_commons-0.5.8 → rb_commons-0.5.9}/setup.py +1 -1
- {rb_commons-0.5.8 → rb_commons-0.5.9}/README.md +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/broker/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/broker/consumer.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/configs/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/configs/config.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/configs/injections.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/configs/rabbitmq.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/http/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/http/base_api.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/http/consul.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/http/exceptions.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/orm/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/orm/exceptions.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/orm/services.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/permissions/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/permissions/role_permissions.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/schemes/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/schemes/jwt.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/schemes/pagination.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/utils/__init__.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons/utils/media.py +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons.egg-info/SOURCES.txt +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons.egg-info/dependency_links.txt +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons.egg-info/requires.txt +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/rb_commons.egg-info/top_level.txt +0 -0
- {rb_commons-0.5.8 → rb_commons-0.5.9}/setup.cfg +0 -0
@@ -2,7 +2,7 @@ from __future__ import annotations
|
|
2
2
|
|
3
3
|
import uuid
|
4
4
|
from typing import TypeVar, Type, Generic, Optional, List, Dict, Literal, Union, Sequence, Any, Iterable
|
5
|
-
from sqlalchemy import select, delete, update, and_, func, desc, inspect, or_
|
5
|
+
from sqlalchemy import select, delete, update, and_, func, desc, inspect, or_, asc
|
6
6
|
from sqlalchemy.exc import IntegrityError, SQLAlchemyError, NoResultFound
|
7
7
|
from sqlalchemy.ext.asyncio import AsyncSession
|
8
8
|
from sqlalchemy.orm import declarative_base, InstrumentedAttribute, selectinload, RelationshipProperty, Load
|
@@ -422,6 +422,25 @@ class BaseManager(Generic[ModelType]):
|
|
422
422
|
self._filtered = True
|
423
423
|
return self
|
424
424
|
|
425
|
+
def sort_by(self, tokens: Sequence[str]) -> "BaseManager[ModelType]":
|
426
|
+
"""
|
427
|
+
Dynamically apply ORDER BY clauses based on a list of "field" or "-field" tokens.
|
428
|
+
"""
|
429
|
+
model = self.model
|
430
|
+
|
431
|
+
for tok in tokens:
|
432
|
+
if not tok:
|
433
|
+
continue
|
434
|
+
direction = desc if tok.startswith("-") else asc
|
435
|
+
name = tok.lstrip("-")
|
436
|
+
col = getattr(model, name, None)
|
437
|
+
if col is None:
|
438
|
+
raise InternalException(f"Cannot sort by unknown field '{name}'")
|
439
|
+
|
440
|
+
self._order_by.append(direction(col))
|
441
|
+
|
442
|
+
return self
|
443
|
+
|
425
444
|
def model_to_dict(self, instance: ModelType, exclude: set[str] | None = None):
|
426
445
|
exclude = exclude or set()
|
427
446
|
return {
|
@@ -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.5.
|
8
|
+
version="0.5.9",
|
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
|
File without changes
|