added docker setup
This commit is contained in:
parent
57ae9c3320
commit
be5ce63add
12 changed files with 509 additions and 20 deletions
|
@ -1,4 +1,4 @@
|
|||
from fastapi import FastAPI, HTTPException, WebSocket, WebSocketDisconnect
|
||||
from fastapi import FastAPI, HTTPException, WebSocket, WebSocketDisconnect, APIRouter
|
||||
from typing import List
|
||||
from models import CreateOrderRequest, Order, DrinkType, MateType
|
||||
from database import db
|
||||
|
@ -11,11 +11,14 @@ app = FastAPI(
|
|||
version="1.0.0"
|
||||
)
|
||||
|
||||
# API Router mit /api Prefix
|
||||
api_router = APIRouter(prefix="/api")
|
||||
|
||||
# Datenbank-Referenz im WebSocketManager setzen
|
||||
websocket_manager.set_database(db)
|
||||
|
||||
|
||||
@app.websocket("/ws")
|
||||
@app.websocket("/api/ws")
|
||||
async def websocket_endpoint(websocket: WebSocket):
|
||||
"""
|
||||
WebSocket-Endpunkt für Echtzeit-Updates der Bestellungen.
|
||||
|
@ -74,7 +77,7 @@ async def websocket_endpoint(websocket: WebSocket):
|
|||
websocket_manager.disconnect(websocket)
|
||||
|
||||
|
||||
@app.post("/orders", response_model=Order, status_code=201)
|
||||
@api_router.post("/orders", response_model=Order, status_code=201)
|
||||
async def create_order(order_request: CreateOrderRequest):
|
||||
"""
|
||||
Erstellt eine neue Bestellung.
|
||||
|
@ -90,7 +93,7 @@ async def create_order(order_request: CreateOrderRequest):
|
|||
return order
|
||||
|
||||
|
||||
@app.get("/orders", response_model=List[Order])
|
||||
@api_router.get("/orders", response_model=List[Order])
|
||||
async def get_all_orders():
|
||||
"""
|
||||
Gibt alle Bestellungen zurück.
|
||||
|
@ -99,7 +102,7 @@ async def get_all_orders():
|
|||
return orders
|
||||
|
||||
|
||||
@app.delete("/orders/{order_id}")
|
||||
@api_router.delete("/orders/{order_id}")
|
||||
async def delete_order(order_id: str):
|
||||
"""
|
||||
Löscht eine spezifische Bestellung.
|
||||
|
@ -115,7 +118,7 @@ async def delete_order(order_id: str):
|
|||
return {"message": f"Bestellung {order_id} wurde erfolgreich gelöscht"}
|
||||
|
||||
|
||||
@app.get("/drinks")
|
||||
@api_router.get("/drinks")
|
||||
async def get_available_drinks():
|
||||
"""
|
||||
Gibt alle verfügbaren Getränketypen zurück.
|
||||
|
@ -126,6 +129,10 @@ async def get_available_drinks():
|
|||
}
|
||||
|
||||
|
||||
# API Router zur App hinzufügen
|
||||
app.include_router(api_router)
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
import uvicorn
|
||||
uvicorn.run(app, host="0.0.0.0", port=8000)
|
Loading…
Add table
Add a link
Reference in a new issue