Compare commits

...

5 Commits
1.2.5 ... 1.3.0

Author SHA1 Message Date
d9f6e82736 Merge pull request #5 from creyD/dev
Co-authored-by: vikbhas <waraa.vignesh@gmail.com>
Co-authored-by: vikynoah <vigneshwaraa.sarangapani@noah.tech>
Co-authored-by: creyD <creyD@users.noreply.github.com>
2024-10-24 11:04:12 +02:00
65e93a023b fix: minor vscode adjustments 2024-10-24 09:32:11 +02:00
creyD
6ce0cfbd14 Adjusted files for isort & autopep 2024-10-24 07:27:26 +00:00
vikynoah
da7ec0b28e Feat: Addition of pagination proxy and Flag functionality (#4)
Co-authored-by: vikbhas <waraa.vignesh@gmail.com>
2024-10-24 09:26:57 +02:00
2727c452b6 fix: adjusted pipeline to dev branch and pull requests 2024-10-24 09:25:39 +02:00
3 changed files with 68 additions and 3 deletions

View File

@@ -4,12 +4,17 @@ on:
push: push:
branches: branches:
- master - master
- dev
paths-ignore: paths-ignore:
- "**/.github/**" - "**/.github/**"
- "**/.gitignore" - "**/.gitignore"
- "**/.vscode/**" - "**/.vscode/**"
- "**/README.md" - "**/README.md"
- "**/CHANGELOG.md" - "**/CHANGELOG.md"
pull_request:
branches:
- master
- dev
workflow_dispatch: workflow_dispatch:
jobs: jobs:
@@ -41,6 +46,7 @@ jobs:
- run: python test.py - run: python test.py
tag_and_publish: tag_and_publish:
if: github.ref == 'refs/heads/master'
runs-on: ubuntu-latest runs-on: ubuntu-latest
needs: test needs: test
permissions: permissions:

View File

@@ -26,10 +26,16 @@
"**/db.sqlite3": true, "**/db.sqlite3": true,
"**/.DS_Store": true, "**/.DS_Store": true,
"**/*.pyc": true, "**/*.pyc": true,
"**/__pycache__/": true "**/__pycache__/": true,
"**/build": true,
"**/dist": true,
"**/*.egg-info": true,
}, },
"search.exclude": { "search.exclude": {
"**/.git": true, "**/.git": true,
"**/build": true,
"**/*.egg-info": true,
"**/dist": true,
"**/.venv": true, "**/.venv": true,
"**/tmp": true, "**/tmp": true,
"htmlcov/*": true, "htmlcov/*": true,

View File

@@ -1,10 +1,21 @@
from math import ceil from math import ceil
from typing import Any, Generic, Optional, Self, Sequence, TypeVar from typing import Any, Generic, Optional, Self, Sequence, TypeVar, Union
from fastapi_pagination import Params from fastapi_pagination import Params
from fastapi_pagination.bases import AbstractPage, AbstractParams from fastapi_pagination.bases import AbstractPage, AbstractParams
from fastapi_pagination.types import GreaterEqualOne, GreaterEqualZero from fastapi_pagination.types import (
GreaterEqualOne,
GreaterEqualZero,
AdditionalData,
SyncItemsTransformer,
)
from fastapi_pagination.api import create_page, apply_items_transformer
from fastapi_pagination.utils import verify_params
from fastapi_pagination.ext.sqlalchemy import create_paginate_query
from pydantic.json_schema import SkipJsonSchema from pydantic.json_schema import SkipJsonSchema
from sqlalchemy.sql.selectable import Select
from sqlalchemy.orm.session import Session
from sqlalchemy import select, func
T = TypeVar("T") T = TypeVar("T")
@@ -70,3 +81,45 @@ def parse_page(response, page: int, size: int) -> Page:
has_next=response.has_next, has_next=response.has_next,
has_prev=response.has_prev, has_prev=response.has_prev,
) )
def create_count_query(query: Select) -> Select:
return select(func.count()).select_from(query.subquery())
def unwrap_scalars(
items: Sequence[Sequence[T]],
force_unwrap: bool = True,
) -> Union[Sequence[T], Sequence[Sequence[T]]]:
return [item[0] if force_unwrap else item for item in items]
def paginate(
connection: Session,
query: Select,
paginationFlag: bool = True,
params: Optional[AbstractParams] = None,
transformer: Optional[SyncItemsTransformer] = None,
additional_data: Optional[AdditionalData] = None,
):
params, raw_params = verify_params(params, "limit-offset", "cursor")
count_query = create_count_query(query)
total = connection.scalar(count_query)
if paginationFlag is False:
params = Params(page=1, size=total)
query = create_paginate_query(query, params)
items = connection.execute(query).all()
items = unwrap_scalars(items)
t_items = apply_items_transformer(items, transformer)
return create_page(
t_items,
params=params,
total=total,
**(additional_data or {}),
)