scheme.py 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import json
  2. from datetime import datetime
  3. from pathlib import Path
  4. from typing import Optional, Dict, Any, List
  5. from pydantic import BaseModel, field_validator
  6. # --- Pydantic 数据模型 ---
  7. class CardImageResponse(BaseModel):
  8. """用于API响应的图片数据模型 (主键为 id)"""
  9. id: int
  10. card_id: int
  11. image_type: str
  12. image_name: Optional[str] = None
  13. image_path: str
  14. detection_json: Dict[str, Any]
  15. modified_json: Optional[Dict[str, Any]] = None
  16. created_at: datetime
  17. updated_at: datetime
  18. class Config:
  19. from_attributes = True
  20. @field_validator('detection_json', 'modified_json', mode='before')
  21. @classmethod
  22. def parse_json_string(cls, v):
  23. if v is None:
  24. return None
  25. if isinstance(v, str):
  26. try:
  27. return json.loads(v)
  28. except json.JSONDecodeError:
  29. raise ValueError("Invalid JSON string in database")
  30. return v
  31. class CardDetailResponse(BaseModel):
  32. """用于响应单个卡牌详细信息的模型 (主键为 id)"""
  33. id: int
  34. card_name: Optional[str] = None
  35. created_at: datetime
  36. updated_at: datetime
  37. detection_score: Optional[float] = None
  38. modified_score: Optional[float] = None
  39. images: List[CardImageResponse] = []
  40. class Config:
  41. from_attributes = True
  42. class ImageJsonPairResponse(BaseModel):
  43. """用于获取单个图片两个JSON数据的响应模型 (主键为 id)"""
  44. id: int # 原 image_id
  45. detection_json: Dict[str, Any]
  46. modified_json: Optional[Dict[str, Any]] = None
  47. class Config:
  48. from_attributes = True
  49. @field_validator('detection_json', 'modified_json', mode='before')
  50. @classmethod
  51. def parse_json_string(cls, v):
  52. if v is None:
  53. return None
  54. if isinstance(v, str):
  55. try:
  56. return json.loads(v)
  57. except json.JSONDecodeError:
  58. raise ValueError("Invalid JSON string in database")
  59. return v
  60. class CardListDetailResponse(BaseModel):
  61. """为新的卡牌列表接口定义的响应模型 (主键为 id)"""
  62. id: int # 原 card_id
  63. card_name: Optional[str] = None
  64. created_at: datetime
  65. updated_at: datetime
  66. class Config:
  67. from_attributes = True