add products

This commit is contained in:
Julien Aldon
2026-02-12 17:39:53 +01:00
parent 025b78d5dd
commit 1a98957466
12 changed files with 129 additions and 75 deletions

View File

@@ -1,4 +1,4 @@
from fastapi import APIRouter, HTTPException, Depends
from fastapi import APIRouter, HTTPException, Depends, Query
import src.messages as messages
import src.models as models
from src.database import get_session
@@ -8,8 +8,12 @@ from src.auth.auth import get_current_user
router = APIRouter(prefix='/products')
#user=Depends(get_current_user)
@router.get('/', response_model=list[models.ProductPublic], )
def get_products(session: Session = Depends(get_session)):
return service.get_all(session)
def get_products(
session: Session = Depends(get_session),
names: list[str] = Query([]),
productors: list[str] = Query([]),
):
return service.get_all(session, names, productors)
@router.get('/{id}', response_model=models.ProductPublic)
def get_product(id: int, session: Session = Depends(get_session)):

View File

@@ -1,8 +1,16 @@
from sqlmodel import Session, select
import src.models as models
def get_all(session: Session) -> list[models.ProductPublic]:
def get_all(
session: Session,
names: list[str],
productors: list[str]
) -> list[models.ProductPublic]:
statement = select(models.Product)
if len(names) > 0:
statement = statement.where(models.Product.name.in_(names))
if len(productors) > 0:
statement = statement.join(models.Productor).where(models.Productor.name.in_(productors))
return session.exec(statement).all()
def get_one(session: Session, product_id: int) -> models.ProductPublic: