Adding filter capacities to api client and server

This commit is contained in:
2025-01-20 16:08:42 +01:00
parent 35448385c5
commit 0a4bec62c1
7 changed files with 32 additions and 36 deletions

View File

@@ -1,6 +1,8 @@
from uuid import UUID, uuid4
from enum import Enum
from typing import Optional
from fastapi_filter.contrib.sqlalchemy import Filter
from sqlmodel import Field, SQLModel, select
class CategoryBase(SQLModel):
@@ -21,8 +23,8 @@ class Category(CategoryRead, table=True):
return category_db
@classmethod
def list(cls):
return select(Category)
def list(cls, filters):
return filters.filter(select(cls))
@classmethod
def get(cls, session, category_id):
@@ -49,3 +51,10 @@ class CategoryCreate(CategoryWrite):
class CategoryUpdate(CategoryWrite):
pass
class CategoryFilters(Filter):
name__like: Optional[str] = None
class Constants(Filter.Constants):
model = Category
search_model_fields = ["name"]