add i18n, products, productors and forms as tables
This commit is contained in:
@@ -16,7 +16,7 @@ async def get_forms(
|
||||
return service.get_all(session, seasons, productors)
|
||||
|
||||
@router.get('/{id}', response_model=models.FormPublic)
|
||||
async def get_forms(id: int, session: Session = Depends(get_session)):
|
||||
async def get_form(id: int, session: Session = Depends(get_session)):
|
||||
result = service.get_one(session, id)
|
||||
if result is None:
|
||||
raise HTTPException(status_code=404, detail=messages.notfound)
|
||||
|
||||
@@ -24,6 +24,7 @@ class ProductorBase(SQLModel):
|
||||
name: str
|
||||
address: str
|
||||
payment: str
|
||||
type: str
|
||||
|
||||
class ProductorPublic(ProductorBase):
|
||||
id: int
|
||||
@@ -38,6 +39,7 @@ class ProductorUpdate(SQLModel):
|
||||
name: str | None
|
||||
address: str | None
|
||||
payment: str | None
|
||||
type: str | None
|
||||
|
||||
class ProductorCreate(ProductorBase):
|
||||
pass
|
||||
|
||||
@@ -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,11 +8,15 @@ import src.productors.service as service
|
||||
router = APIRouter(prefix='/productors')
|
||||
|
||||
@router.get('/', response_model=list[models.ProductorPublic])
|
||||
def get_productors(session: Session = Depends(get_session)):
|
||||
return service.get_all(session)
|
||||
def get_productors(
|
||||
names: list[str] = Query([]),
|
||||
types: list[str] = Query([]),
|
||||
session: Session = Depends(get_session)
|
||||
):
|
||||
return service.get_all(session, names, types)
|
||||
|
||||
@router.get('/{id}', response_model=models.ProductorPublic)
|
||||
def get_productors(id: int, session: Session = Depends(get_session)):
|
||||
def get_productor(id: int, session: Session = Depends(get_session)):
|
||||
result = service.get_one(session, id)
|
||||
if result is None:
|
||||
raise HTTPException(status_code=404, detail=messages.notfound)
|
||||
|
||||
@@ -1,8 +1,12 @@
|
||||
from sqlmodel import Session, select
|
||||
import src.models as models
|
||||
|
||||
def get_all(session: Session) -> list[models.ProductorPublic]:
|
||||
def get_all(session: Session, names: list[str], types: list[str]) -> list[models.ProductorPublic]:
|
||||
statement = select(models.Productor)
|
||||
if len(names) > 0:
|
||||
statement.where(models.Productor.name.in_(names))
|
||||
if len(types) > 0:
|
||||
statement.where(models.Productor.type.in_(types))
|
||||
return session.exec(statement).all()
|
||||
|
||||
def get_one(session: Session, productor_id: int) -> models.ProductorPublic:
|
||||
|
||||
@@ -12,7 +12,7 @@ def get_templates(session: Session = Depends(get_session)):
|
||||
return service.get_all(session)
|
||||
|
||||
@router.get('/{id}', response_model=models.TemplatePublic)
|
||||
def get_templates(id: int, session: Session = Depends(get_session)):
|
||||
def get_template(id: int, session: Session = Depends(get_session)):
|
||||
result = service.get_one(session, id)
|
||||
if result is None:
|
||||
raise HTTPException(status_code=404, detail=messages.notfound)
|
||||
|
||||
Reference in New Issue
Block a user