import json import logging import time from fastapi import APIRouter, HTTPException from app.schemas.image2sketch import Image2SketchModel from app.schemas.response_template import ResponseModel from app.service.image2sketch.server import Image2SketchServer router = APIRouter() logger = logging.getLogger() @router.post("/image2sketch") def image2sketch(request_item: Image2SketchModel): """ 创建一个具有以下参数的请求体: - **image_url**: 提取图片url - **sketch_bucket**: sketch保存的bucket - **sketch_name**: sketch保存的object name 示例参数: { "image_url": "test/real_Top_971fe3085a69f31f3e66c225eabb0eea.jpg_Img.jpg", "sketch_bucket": "test", "sketch_name": "12341556-89.jpg" } """ try: start_time = time.time() logger.info(f"image2sketch request item is : @@@@@@:{json.dumps(request_item.dict())}") service = Image2SketchServer(request_item) sketch_url = service.get_result() logger.info(f"run time is : {time.time() - start_time}") except Exception as e: logger.warning(f"image2sketch Run Exception @@@@@@:{e}") raise HTTPException(status_code=404, detail=str(e)) return ResponseModel(data=sketch_url)