schema.py 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. from fastapi import Query
  2. from pydantic import BaseModel, ConfigDict, Field, field_validator
  3. from app.common.enums import QueueEnum
  4. from app.core.base_schema import BaseSchema, UserBySchema
  5. from app.core.validator import DateTimeStr
  6. class PositionCreateSchema(BaseModel):
  7. """岗位创建模型"""
  8. name: str = Field(..., max_length=64, description="岗位名称")
  9. order: int = Field(default=1, ge=1, description="显示排序")
  10. status: str = Field(default="0", description="是否启用(0:启用 1:禁用)")
  11. description: str | None = Field(default=None, max_length=255, description="描述")
  12. @field_validator("name")
  13. @classmethod
  14. def _validate_name(cls, v: str) -> str:
  15. v = v.strip()
  16. if not v:
  17. raise ValueError("岗位名称不能为空")
  18. return v
  19. class PositionUpdateSchema(PositionCreateSchema):
  20. """岗位更新模型"""
  21. class PositionOutSchema(PositionCreateSchema, BaseSchema, UserBySchema):
  22. """岗位信息响应模型"""
  23. model_config = ConfigDict(from_attributes=True)
  24. class PositionQueryParam:
  25. """岗位管理查询参数"""
  26. def __init__(
  27. self,
  28. name: str | None = Query(None, description="岗位名称"),
  29. description: str | None = Query(None, description="描述"),
  30. status: str | None = Query(None, description="是否启用"),
  31. created_time: list[DateTimeStr] | None = Query(
  32. None,
  33. description="创建时间范围",
  34. examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"],
  35. ),
  36. updated_time: list[DateTimeStr] | None = Query(
  37. None,
  38. description="更新时间范围",
  39. examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"],
  40. ),
  41. created_id: int | None = Query(None, description="创建人"),
  42. updated_id: int | None = Query(None, description="更新人"),
  43. ) -> None:
  44. # 模糊查询字段
  45. self.name = (QueueEnum.like.value, name)
  46. if description:
  47. self.description = (QueueEnum.like.value, description)
  48. # 精确查询字段
  49. if status:
  50. self.status = (QueueEnum.eq.value, status)
  51. # 时间范围查询
  52. if created_time and len(created_time) == 2:
  53. self.created_time = (QueueEnum.between.value, (created_time[0], created_time[1]))
  54. if updated_time and len(updated_time) == 2:
  55. self.updated_time = (QueueEnum.between.value, (updated_time[0], updated_time[1]))
  56. # 关联查询字段
  57. if created_id:
  58. self.created_id = (QueueEnum.eq.value, created_id)
  59. if updated_id:
  60. self.updated_id = (QueueEnum.eq.value, updated_id)