add endpoints to get items by id
This commit is contained in:
@@ -1,6 +1,6 @@
|
||||
from typing import List
|
||||
|
||||
from fastapi import APIRouter
|
||||
from fastapi import APIRouter, HTTPException
|
||||
|
||||
from src.db.models.tysc import FieldPosition
|
||||
from src.db.session import SessionDep
|
||||
@@ -10,10 +10,18 @@ from src.schema.tysc.fieldposition import FieldPositionResponse, to_response
|
||||
router = APIRouter()
|
||||
|
||||
@router.get("/positions")
|
||||
def get_all_teams(db: SessionDep) -> List[FieldPositionResponse]:
|
||||
def get_all_positions(db: SessionDep) -> List[FieldPositionResponse]:
|
||||
results: list[FieldPositionResponse] = []
|
||||
sports = db.query(FieldPosition).all()
|
||||
for sport in sports:
|
||||
response = to_response(sport)
|
||||
positions = db.query(FieldPosition).all()
|
||||
for position in positions:
|
||||
response = to_response(position)
|
||||
results.append(response)
|
||||
return results
|
||||
|
||||
@router.get("/positions/{position_id}", response_model=FieldPositionResponse)
|
||||
def get_position(position_id: str, db: SessionDep) -> FieldPositionResponse:
|
||||
position = db.get(FieldPosition, position_id)
|
||||
if position is None:
|
||||
raise HTTPException(status_code=404, detail="Fieldposition could not be found")
|
||||
response = to_response(position)
|
||||
return response
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
from typing import List
|
||||
|
||||
from fastapi import APIRouter
|
||||
from fastapi import APIRouter, HTTPException
|
||||
|
||||
from src.db.models.tysc import Player
|
||||
from src.db.session import SessionDep
|
||||
@@ -17,3 +17,11 @@ def get_all_players(db: SessionDep) -> List[PlayerResponse]:
|
||||
response = to_response(player)
|
||||
results.append(response)
|
||||
return results
|
||||
|
||||
@router.get("/players/{player_id}", response_model=PlayerResponse)
|
||||
def get_player(player_id: str, db: SessionDep) -> PlayerResponse:
|
||||
player = db.get(Player, player_id)
|
||||
if player is None:
|
||||
raise HTTPException(status_code=404, detail="Player could not be found")
|
||||
response = to_response(player)
|
||||
return response
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
from typing import List
|
||||
|
||||
from fastapi import APIRouter
|
||||
from fastapi import APIRouter, HTTPException
|
||||
|
||||
from src.db.models.tysc import Rooster
|
||||
from src.db.session import SessionDep
|
||||
@@ -10,10 +10,18 @@ from src.schema.tysc.rooster import RoosterResponse, to_response
|
||||
router = APIRouter()
|
||||
|
||||
@router.get("/roosters")
|
||||
def get_all_sports(db: SessionDep) -> List[RoosterResponse]:
|
||||
def get_all_roosters(db: SessionDep) -> List[RoosterResponse]:
|
||||
results: list[RoosterResponse] = []
|
||||
roosters = db.query(Rooster).all()
|
||||
for rooster in roosters:
|
||||
response = to_response(rooster)
|
||||
results.append(response)
|
||||
return results
|
||||
|
||||
@router.get("/roosters/{rooster_id}", response_model=RoosterResponse)
|
||||
def get_rooster(rooster_id: str, db: SessionDep) -> RoosterResponse:
|
||||
rooster = db.get(Rooster, rooster_id)
|
||||
if rooster is None:
|
||||
raise HTTPException(status_code=404, detail="Rooster could not be found")
|
||||
response = to_response(rooster)
|
||||
return response
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
from typing import List
|
||||
from fastapi import APIRouter
|
||||
from fastapi import APIRouter, HTTPException
|
||||
|
||||
from src.core.log_conf import logger
|
||||
from src.db.session import SessionDep
|
||||
from src.schema.tysc.sport import SportResponse, to_response
|
||||
from src.db.models.tysc import Sport
|
||||
@@ -15,3 +16,13 @@ def get_all_sports(db: SessionDep) -> List[SportResponse]:
|
||||
response = to_response(sport)
|
||||
results.append(response)
|
||||
return results
|
||||
|
||||
@router.get("/sports/{sport_id}", response_model=SportResponse)
|
||||
def get_sport(sport_id: str, db: SessionDep) -> SportResponse:
|
||||
sport = db.get(Sport, sport_id)
|
||||
if sport is None:
|
||||
raise HTTPException(status_code=404, detail="Sport could not be found")
|
||||
logger.debug(f"create SportResponse for {sport}")
|
||||
response: SportResponse = to_response(sport)
|
||||
return response
|
||||
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
from typing import List
|
||||
|
||||
from fastapi import APIRouter
|
||||
from fastapi import APIRouter, HTTPException
|
||||
|
||||
from src.db.models.tysc import Team
|
||||
from src.db.session import SessionDep
|
||||
@@ -12,8 +12,16 @@ router = APIRouter()
|
||||
@router.get("/teams")
|
||||
def get_all_teams(db: SessionDep) -> List[TeamResponse]:
|
||||
results: list[TeamResponse] = []
|
||||
sports = db.query(Team).all()
|
||||
for sport in sports:
|
||||
response = to_response(sport)
|
||||
teams = db.query(Team).all()
|
||||
for team in teams:
|
||||
response = to_response(team)
|
||||
results.append(response)
|
||||
return results
|
||||
|
||||
@router.get("/teams/{team_id}", response_model=TeamResponse)
|
||||
def get_team(team_id: str, db: SessionDep) -> TeamResponse:
|
||||
team = db.get(Team, team_id)
|
||||
if team is None:
|
||||
raise HTTPException(status_code=404, detail="Team could not be found")
|
||||
response = to_response(team)
|
||||
return response
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
from typing import List
|
||||
|
||||
from fastapi import APIRouter
|
||||
from fastapi import APIRouter, HTTPException
|
||||
|
||||
from src.db.models.tysc import Vendor
|
||||
from src.db.session import SessionDep
|
||||
@@ -20,3 +20,14 @@ def get_all_vendors(db: SessionDep) -> List[VendorResponse]:
|
||||
response = to_response(vendor)
|
||||
results.append(response)
|
||||
return results
|
||||
|
||||
@router.get("/vendors/{vendor_id}", response_model=VendorResponse)
|
||||
def get_vendor(vendor_id: str, db: SessionDep) -> VendorResponse:
|
||||
"""
|
||||
retrieve vendor by id as json response.
|
||||
"""
|
||||
vendor = db.get(Vendor, vendor_id)
|
||||
if vendor is None:
|
||||
raise HTTPException(status_code=404, detail="Vendor could not be found")
|
||||
response = to_response(vendor)
|
||||
return response
|
||||
|
||||
Reference in New Issue
Block a user