crud.py 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. # -*- coding: utf-8 -*-
  2. from typing import Sequence, Any
  3. from app.core.base_crud import CRUDBase
  4. from ..auth.schema import AuthSchema
  5. from .model import PositionModel
  6. from .schema import PositionCreateSchema, PositionUpdateSchema
  7. class PositionCRUD(CRUDBase[PositionModel, PositionCreateSchema, PositionUpdateSchema]):
  8. """岗位模块数据层"""
  9. def __init__(self, auth: AuthSchema) -> None:
  10. """
  11. 初始化岗位CRUD
  12. 参数:
  13. - auth (AuthSchema): 认证信息模型
  14. """
  15. self.auth = auth
  16. super().__init__(model=PositionModel, auth=auth)
  17. async def get_by_id_crud(self, id: int, preload: list[str] | None = None) -> PositionModel | None:
  18. """
  19. 根据 id 获取岗位信息。
  20. 参数:
  21. - id (int): 岗位 ID。
  22. - preload (list[str] | None): 预加载关系,未提供时使用模型默认项
  23. 返回:
  24. - PositionModel | None: 岗位信息,未找到返回 None。
  25. """
  26. return await self.get(id=id, preload=preload)
  27. async def get_list_crud(self, search: dict | None = None, order_by: list[dict[str, Any]] | None = None, preload: list[str] | None = None) -> Sequence[PositionModel]:
  28. """
  29. 获取岗位列表。
  30. 参数:
  31. - search (dict | None): 搜索条件。
  32. - order_by (list[dict[str, Any]] | None): 排序字段列表。
  33. - preload (list[str] | None): 预加载关系,未提供时使用模型默认项
  34. 返回:
  35. - Sequence[PositionModel]: 岗位列表。
  36. """
  37. return await self.list(search=search, order_by=order_by, preload=preload)
  38. async def set_available_crud(self, ids: list[int], status: str) -> None:
  39. """
  40. 批量设置岗位可用状态。
  41. 参数:
  42. - ids (list[int]): 岗位 ID 列表。
  43. - status (bool): 可用状态。
  44. 返回:
  45. - None
  46. """
  47. await self.set(ids=ids, status=status)
  48. async def get_name_crud(self, ids: list[int]) -> list[str]:
  49. """
  50. 根据 id 列表获取岗位名称。
  51. 参数:
  52. - ids (list[int]): 岗位 ID 列表。
  53. 返回:
  54. - list[str]: 岗位名称列表。
  55. """
  56. position_names = []
  57. for id in ids:
  58. obj = await self.get(id=id)
  59. if obj:
  60. position_names.append(obj.name)
  61. return position_names