Files
home_hub/backend/app/api/media.py
T
gilles 3dbd554eeb fix(media): upload photo — taille, formats et nginx
- nginx : client_max_body_size 15m (photos smartphone > 1 Mo rejetées silencieusement)
- backend : redimensionnement original à 500×500 max (aspect ratio conservé) avant sauvegarde WEBP
- backend : thumbnail généré depuis l'image déjà redimensionnée (économie mémoire)
- backend : formats acceptés étendus — image/heic, image/heif, image/jpg
- backend : normalisation content-type en lowercase (robustesse navigateurs)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-25 13:29:45 +02:00

34 lines
1.2 KiB
Python

from fastapi import APIRouter, UploadFile, File, Query, HTTPException
from fastapi.responses import Response
from app.schemas.media import MediaUploadResponse
from app.services.media import save_image, save_audio, delete_media, ALLOWED_IMAGE_TYPES, ALLOWED_AUDIO_TYPES
router = APIRouter()
@router.post("/upload", response_model=MediaUploadResponse)
async def upload_media(
file: UploadFile = File(...),
context: str = Query(default="note", pattern="^(product|note|attachment)$"),
):
content_type = (file.content_type or "").lower()
if content_type in ALLOWED_IMAGE_TYPES:
result = await save_image(file, context=context)
elif content_type in ALLOWED_AUDIO_TYPES:
result = await save_audio(file)
else:
raise HTTPException(status_code=400, detail=f"Type de fichier non supporté : {content_type}")
return MediaUploadResponse(**result)
@router.delete("/{file_id}", status_code=204)
async def delete_media_endpoint(
file_id: str,
file_path: str = Query(...),
thumbnail_path: str | None = Query(default=None),
):
delete_media(file_id=file_id, file_path=file_path, thumbnail_path=thumbnail_path)
return Response(status_code=204)