Some checks failed
SonarQube Analysis / SonarQube Scan (push) Has been cancelled
- H/F/I/O SS304/GRAPHITE/CS/CS 패턴에서 4개 구성요소 모두 표시 - 기존 SS304 + GRAPHITE → SS304/GRAPHITE/CS/CS로 완전한 구성 표시 - 외부링/필러/내부링/추가구성 모든 정보 포함 - 구매수량 계산 모달에서 정확한 재질 정보 확인 가능
57 lines
1.6 KiB
Python
57 lines
1.6 KiB
Python
"""
|
|
파일 관리 API
|
|
main.py에서 분리된 파일 관련 엔드포인트들
|
|
"""
|
|
from fastapi import APIRouter, Depends
|
|
from sqlalchemy import text
|
|
from sqlalchemy.orm import Session
|
|
from typing import Optional
|
|
|
|
from ..database import get_db
|
|
from ..utils.logger import get_logger
|
|
from ..schemas import FileListResponse, FileDeleteResponse, FileInfo
|
|
from ..services.file_service import get_file_service
|
|
|
|
router = APIRouter()
|
|
logger = get_logger(__name__)
|
|
|
|
|
|
@router.get("/files", response_model=FileListResponse)
|
|
async def get_files(
|
|
job_no: Optional[str] = None,
|
|
show_history: bool = False,
|
|
use_cache: bool = True,
|
|
db: Session = Depends(get_db)
|
|
) -> FileListResponse:
|
|
"""파일 목록 조회 (BOM별 그룹화)"""
|
|
file_service = get_file_service(db)
|
|
|
|
# 서비스 레이어 호출
|
|
files, cache_hit = await file_service.get_files(job_no, show_history, use_cache)
|
|
|
|
return FileListResponse(
|
|
success=True,
|
|
message="파일 목록 조회 성공" + (" (캐시)" if cache_hit else ""),
|
|
data=files,
|
|
total_count=len(files),
|
|
cache_hit=cache_hit
|
|
)
|
|
|
|
|
|
@router.delete("/files/{file_id}", response_model=FileDeleteResponse)
|
|
async def delete_file(
|
|
file_id: int,
|
|
db: Session = Depends(get_db)
|
|
) -> FileDeleteResponse:
|
|
"""파일 삭제"""
|
|
file_service = get_file_service(db)
|
|
|
|
# 서비스 레이어 호출
|
|
result = await file_service.delete_file(file_id)
|
|
|
|
return FileDeleteResponse(
|
|
success=result["success"],
|
|
message=result["message"],
|
|
deleted_file_id=result["deleted_file_id"]
|
|
)
|