| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- # -*- coding: utf-8 -*-
- from typing import Optional
- from pydantic import BaseModel, ConfigDict, Field, field_validator
- from fastapi import Query
- from app.core.validator import DateTimeStr
- from app.core.base_schema import BaseSchema, UserBySchema
- class PositionCreateSchema(BaseModel):
- """岗位创建模型"""
- name: str = Field(..., max_length=64, description="岗位名称")
- order: int = Field(default=1, ge=1, description='显示排序')
- status: str = Field(default="0", description="是否启用(0:启用 1:禁用)")
- description: str | None = Field(default=None, max_length=255, description="描述")
- @field_validator('name')
- @classmethod
- def _validate_name(cls, v: str) -> str:
- v = v.strip()
- if not v:
- raise ValueError('岗位名称不能为空')
- return v
- class PositionUpdateSchema(PositionCreateSchema):
- """岗位更新模型"""
- ...
- class PositionOutSchema(PositionCreateSchema, BaseSchema, UserBySchema):
- """岗位信息响应模型"""
- model_config = ConfigDict(from_attributes=True)
- ...
- class PositionQueryParam:
- """岗位管理查询参数"""
- def __init__(
- self,
- name: Optional[str] = Query(None, description="岗位名称"),
- status: Optional[str] = Query(None, description="是否可用"),
- created_time: list[DateTimeStr] | None = Query(None, description="创建时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
- updated_time: list[DateTimeStr] | None = Query(None, description="更新时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
- created_id: int | None = Query(None, description="创建人"),
- updated_id: int | None = Query(None, description="更新人"),
- ) -> None:
-
- # 模糊查询字段
- self.name = ("like", name)
- # 精确查询字段
- self.created_id = created_id
- self.updated_id = updated_id
- self.status = status
-
- # 时间范围查询
- if created_time and len(created_time) == 2:
- self.created_time = ("between", (created_time[0], created_time[1]))
- if updated_time and len(updated_time) == 2:
- self.updated_time = ("between", (updated_time[0], updated_time[1]))
-
|