24 lines
933 B
Python
24 lines
933 B
Python
from typing import List
|
|
from fastapi import APIRouter, Depends, HTTPException
|
|
from sqlalchemy.orm import Session
|
|
from app.api.v1.models.user import User
|
|
from app.api.v1.schemas.user import UserCreate, UserRead
|
|
from app.api.core.dependencies.dependencies import get_db
|
|
router = APIRouter()
|
|
@router.get("/users", response_model=List[UserRead])
|
|
def read_users(db: Session = Depends(get_db)):
|
|
users = db.query(User).all()
|
|
return users
|
|
@router.post("/users", response_model=UserRead)
|
|
def create_user(user: UserCreate, db: Session = Depends(get_db)):
|
|
db_user = User(**user.dict())
|
|
db.add(db_user)
|
|
db.commit()
|
|
db.refresh(db_user)
|
|
return db_user
|
|
@router.get("/users/{user_id}", response_model=UserRead)
|
|
def read_user(user_id: int, db: Session = Depends(get_db)):
|
|
db_user = db.query(User).get(user_id)
|
|
if not db_user:
|
|
raise HTTPException(status_code=404, detail="User not found")
|
|
return db_user |