schema.py 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. # -*- coding: utf-8 -*-
  2. from pydantic import BaseModel, ConfigDict, Field, field_validator
  3. from fastapi import Query
  4. from app.core.validator import DateTimeStr
  5. from app.core.base_schema import BaseSchema
  6. class DeptCreateSchema(BaseModel):
  7. """部门创建模型"""
  8. name: str = Field(..., max_length=40, description="部门名称")
  9. order: int = Field(default=1, ge=0, description="显示顺序")
  10. code: str | None = Field(default=None, max_length=60, description="部门编码")
  11. leader: str | None = Field(default=None, max_length=20, description="部门负责人")
  12. phone: str | None = Field(default=None, max_length=11, description="手机")
  13. email: str | None = Field(default=None, max_length=64, description="邮箱")
  14. parent_id: int | None = Field(default=None, ge=0, description="父部门ID")
  15. status: str = Field(default="0", description="是否启用(0:启用 1:禁用)")
  16. description: str | None = Field(default=None, max_length=255, description="备注说明")
  17. @field_validator('name')
  18. @classmethod
  19. def validate_name(cls, value: str):
  20. if not value or len(value.strip()) == 0:
  21. raise ValueError("部门名称不能为空")
  22. value = value.replace(" ", "")
  23. return value
  24. @field_validator('code')
  25. @classmethod
  26. def validate_code(cls, value: str | None):
  27. if value is None:
  28. return value
  29. v = value.strip()
  30. if v == "":
  31. return None
  32. import re
  33. if not re.match(r'^[A-Za-z][A-Za-z0-9_]*$', v):
  34. raise ValueError("部门编码必须以字母开头,且仅包含字母/数字/下划线")
  35. return v
  36. class DeptUpdateSchema(DeptCreateSchema):
  37. """部门更新模型"""
  38. ...
  39. class DeptOutSchema(DeptCreateSchema, BaseSchema):
  40. """部门响应模型"""
  41. model_config = ConfigDict(from_attributes=True)
  42. parent_name: str | None = Field(default=None, max_length=64, description="父部门名称")
  43. class DeptQueryParam:
  44. """部门管理查询参数"""
  45. def __init__(
  46. self,
  47. name: str | None = Query(None, description="部门名称"),
  48. status: str | None = Query(None, description="部门状态(True正常 False停用)"),
  49. created_time: list[DateTimeStr] | None = Query(None, description="创建时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
  50. updated_time: list[DateTimeStr] | None = Query(None, description="更新时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
  51. ) -> None:
  52. # 模糊查询字段
  53. self.name = ("like", name)
  54. # 精确查询字段
  55. self.status = status
  56. # 时间范围查询
  57. if created_time and len(created_time) == 2:
  58. self.created_time = ("between", (created_time[0], created_time[1]))
  59. if updated_time and len(updated_time) == 2:
  60. self.updated_time = ("between", (updated_time[0], updated_time[1]))