
- Setup project structure with FastAPI app - Create SQLAlchemy models for categories, questions, quizzes, and results - Implement API endpoints for all CRUD operations - Set up Alembic migrations for database schema management - Add comprehensive documentation in README.md
32 lines
1.4 KiB
Python
32 lines
1.4 KiB
Python
from fastapi import APIRouter, Depends, HTTPException, status
|
|
from sqlalchemy.orm import Session
|
|
from typing import List
|
|
|
|
from app.db.session import get_db
|
|
from app.schemas.result import ResultCreate, ResultResponse
|
|
from app.services.result import create_result, get_result, get_results, get_user_results
|
|
|
|
router = APIRouter()
|
|
|
|
@router.post("/", response_model=ResultResponse, status_code=status.HTTP_201_CREATED)
|
|
def create_result_endpoint(result_data: ResultCreate, db: Session = Depends(get_db)):
|
|
"""Create a new quiz result"""
|
|
return create_result(db=db, result_data=result_data)
|
|
|
|
@router.get("/{result_id}", response_model=ResultResponse)
|
|
def get_result_endpoint(result_id: int, db: Session = Depends(get_db)):
|
|
"""Get a specific result by ID"""
|
|
db_result = get_result(db=db, result_id=result_id)
|
|
if db_result is None:
|
|
raise HTTPException(status_code=404, detail="Result not found")
|
|
return db_result
|
|
|
|
@router.get("/", response_model=List[ResultResponse])
|
|
def get_results_endpoint(skip: int = 0, limit: int = 100, db: Session = Depends(get_db)):
|
|
"""Get all results"""
|
|
return get_results(db=db, skip=skip, limit=limit)
|
|
|
|
@router.get("/user/{user_id}", response_model=List[ResultResponse])
|
|
def get_user_results_endpoint(user_id: str, db: Session = Depends(get_db)):
|
|
"""Get all results for a specific user"""
|
|
return get_user_results(db=db, user_id=user_id) |