from fastapi import APIRouter, Depends, HTTPException from sqlalchemy.orm import Session from app import models, schemas from app.auth import get_current_user from app.database import get_db router = APIRouter() def _owner_config(config_id: int, db: Session, user: models.User) -> models.Config: config = db.query(models.Config).filter( models.Config.id == config_id, models.Config.owner_id == user.id ).first() if not config: raise HTTPException(status_code=404, detail="Config not found") return config @router.get("/{config_id}/masq", response_model=list[schemas.MasqOut]) def list_masq(config_id: int, db: Session = Depends(get_db), user: models.User = Depends(get_current_user)): _owner_config(config_id, db, user) return db.query(models.Masq).filter(models.Masq.config_id == config_id).all() @router.post("/{config_id}/masq", response_model=schemas.MasqOut, status_code=201) def create_masq(config_id: int, body: schemas.MasqCreate, db: Session = Depends(get_db), user: models.User = Depends(get_current_user)): _owner_config(config_id, db, user) masq = models.Masq(**body.model_dump(), config_id=config_id) db.add(masq) db.commit() db.refresh(masq) return masq @router.get("/{config_id}/masq/{masq_id}", response_model=schemas.MasqOut) def get_masq(config_id: int, masq_id: int, db: Session = Depends(get_db), user: models.User = Depends(get_current_user)): _owner_config(config_id, db, user) masq = db.query(models.Masq).filter(models.Masq.id == masq_id, models.Masq.config_id == config_id).first() if not masq: raise HTTPException(status_code=404, detail="Masq entry not found") return masq @router.put("/{config_id}/masq/{masq_id}", response_model=schemas.MasqOut) def update_masq(config_id: int, masq_id: int, body: schemas.MasqUpdate, db: Session = Depends(get_db), user: models.User = Depends(get_current_user)): _owner_config(config_id, db, user) masq = db.query(models.Masq).filter(models.Masq.id == masq_id, models.Masq.config_id == config_id).first() if not masq: raise HTTPException(status_code=404, detail="Masq entry not found") for field, value in body.model_dump(exclude_none=True).items(): setattr(masq, field, value) db.commit() db.refresh(masq) return masq @router.delete("/{config_id}/masq/{masq_id}", status_code=204) def delete_masq(config_id: int, masq_id: int, db: Session = Depends(get_db), user: models.User = Depends(get_current_user)): _owner_config(config_id, db, user) masq = db.query(models.Masq).filter(models.Masq.id == masq_id, models.Masq.config_id == config_id).first() if not masq: raise HTTPException(status_code=404, detail="Masq entry not found") db.delete(masq) db.commit()