base_params.py 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. # -*- coding: utf-8 -*-
  2. from fastapi import Query
  3. class PaginationQueryParam:
  4. """分页查询参数基类"""
  5. def __init__(
  6. self,
  7. page_no: int = Query(default=1, description="当前页码", ge=1),
  8. page_size: int = Query(default=10, description="每页数量", ge=1, le=100),
  9. order_by: str | None = Query(default=None, description="排序字段,格式:field1,asc;field2,desc"),
  10. ) -> None:
  11. """
  12. 初始化分页查询参数。
  13. 参数:
  14. - page_no (int | None): 当前页码,默认 None。
  15. - page_size (int | None): 每页数量,默认 None,最大 100。
  16. - order_by (str | None): 排序字段,格式 'field,asc;field2,desc'。
  17. 返回:
  18. - None
  19. """
  20. self.page_no = page_no
  21. self.page_size = page_size
  22. # 将字符串格式的order_by转换为服务层需要的List[Dict[str, str]]格式
  23. if order_by:
  24. try:
  25. self.order_by = []
  26. for item in order_by.split(';'):
  27. if item.strip():
  28. field, direction = item.split(',', 1)
  29. self.order_by.append({field.strip(): direction.strip().lower()})
  30. except ValueError:
  31. # 如果解析失败,使用默认排序
  32. self.order_by = [{'updated_time': 'desc'}]
  33. else:
  34. self.order_by = [{'updated_time': 'desc'}]