schema.py 2.3 KB

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