schema.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. # -*- coding: utf-8 -*-
  2. from pydantic import BaseModel, ConfigDict, Field, field_validator
  3. from urllib.parse import urlparse
  4. from fastapi import Query
  5. from app.core.validator import DateTimeStr
  6. from app.core.base_schema import BaseSchema, UserBySchema
  7. class ApplicationCreateSchema(BaseModel):
  8. """应用创建模型"""
  9. name: str = Field(..., max_length=64, description='应用名称')
  10. access_url: str = Field(..., max_length=255, description="访问地址")
  11. icon_url: str | None = Field(None, max_length=300, description="应用图标URL")
  12. status: str = Field("0", description="是否启用(0:启用 1:禁用)")
  13. description: str | None = Field(default=None, max_length=255, description="描述")
  14. @field_validator('access_url')
  15. @classmethod
  16. def _validate_access_url(cls, v: str) -> str:
  17. v = v.strip()
  18. if not v:
  19. raise ValueError('访问地址不能为空')
  20. parsed = urlparse(v)
  21. if parsed.scheme not in ('http', 'https'):
  22. raise ValueError('访问地址必须为 http/https URL')
  23. return v
  24. @field_validator('icon_url')
  25. @classmethod
  26. def _validate_icon_url(cls, v: str | None) -> str | None:
  27. if v is None:
  28. return v
  29. v = v.strip()
  30. if v == "":
  31. return None
  32. parsed = urlparse(v)
  33. if parsed.scheme not in ('http', 'https'):
  34. raise ValueError('应用图标URL必须为 http/https URL')
  35. return v
  36. class ApplicationUpdateSchema(ApplicationCreateSchema):
  37. """应用更新模型"""
  38. ...
  39. class ApplicationOutSchema(ApplicationCreateSchema, BaseSchema, UserBySchema):
  40. """应用响应模型"""
  41. model_config = ConfigDict(from_attributes=True)
  42. class ApplicationQueryParam:
  43. """应用系统查询参数"""
  44. def __init__(
  45. self,
  46. name: str | None = Query(None, description="应用名称"),
  47. status: str | None = Query(None, description="是否启用"),
  48. created_time: list[DateTimeStr] | None = Query(None, description="创建时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
  49. updated_time: list[DateTimeStr] | None = Query(None, description="更新时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
  50. created_id: int | None = Query(None, description="创建人"),
  51. updated_id: int | None = Query(None, description="更新人"),
  52. ) -> None:
  53. # 模糊查询字段
  54. self.name = ("like", name) if name else None
  55. # 精确查询字段
  56. self.status = status
  57. self.created_id = created_id
  58. self.updated_id = updated_id
  59. # 时间范围查询
  60. if created_time and len(created_time) == 2:
  61. self.created_time = ("between", (created_time[0], created_time[1]))
  62. if updated_time and len(updated_time) == 2:
  63. self.updated_time = ("between", (updated_time[0], updated_time[1]))