schema.py 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. # -*- coding: utf-8 -*-
  2. from pydantic import BaseModel, ConfigDict, Field, field_validator, model_validator
  3. from fastapi import Query
  4. from app.core.validator import DateTimeStr
  5. from app.core.base_schema import BaseSchema, UserBySchema
  6. class NoticeCreateSchema(BaseModel):
  7. """公告通知创建模型"""
  8. notice_title: str = Field(..., max_length=50, description='公告标题')
  9. notice_type: str = Field(..., description='公告类型(1通知 2公告)')
  10. notice_content: str = Field(..., description='公告内容')
  11. status: str = Field(default="0", description="是否启用(0:启用 1:禁用)")
  12. description: str | None = Field(default=None, max_length=255, description="描述")
  13. @field_validator("notice_type")
  14. @classmethod
  15. def _validate_notice_type(cls, value: str):
  16. if value not in {"1", "2"}:
  17. raise ValueError("公告类型仅支持 '1'(通知) 或 '2'(公告)")
  18. return value
  19. @model_validator(mode='after')
  20. def _validate_after(self):
  21. if not self.notice_title.strip():
  22. raise ValueError("公告标题不能为空")
  23. if not self.notice_content.strip():
  24. raise ValueError("公告内容不能为空")
  25. return self
  26. class NoticeUpdateSchema(NoticeCreateSchema):
  27. """公告通知更新模型"""
  28. ...
  29. class NoticeOutSchema(NoticeCreateSchema, BaseSchema, UserBySchema):
  30. """公告通知响应模型"""
  31. model_config = ConfigDict(from_attributes=True)
  32. class NoticeQueryParam:
  33. """公告通知查询参数"""
  34. def __init__(
  35. self,
  36. notice_title: str | None = Query(None, description="公告标题"),
  37. notice_type: str | None = Query(None, description="公告类型"),
  38. status: str | None = Query(None, description="是否可用"),
  39. created_time: list[DateTimeStr] | None = Query(None, description="创建时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
  40. updated_time: list[DateTimeStr] | None = Query(None, description="更新时间范围", examples=["2025-01-01 00:00:00", "2025-12-31 23:59:59"]),
  41. created_id: int | None = Query(None, description="创建人"),
  42. updated_id: int | None = Query(None, description="更新人"),
  43. ) -> None:
  44. # 模糊查询字段
  45. self.notice_title = ("like", notice_title)
  46. # 精确查询字段
  47. self.created_id = created_id
  48. self.updated_id = updated_id
  49. self.status = status
  50. self.notice_type = notice_type
  51. # 时间范围查询
  52. if created_time and len(created_time) == 2:
  53. self.created_time = ("between", (created_time[0], created_time[1]))
  54. if updated_time and len(updated_time) == 2:
  55. self.updated_time = ("between", (updated_time[0], updated_time[1]))