add i18n, products, productors and forms as tables

This commit is contained in:
2026-02-12 00:30:28 +01:00
parent 1813e2893e
commit 025b78d5dd
43 changed files with 1623 additions and 527 deletions

View File

@@ -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)

View File

@@ -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

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,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)

View File

@@ -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:

View File

@@ -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)