crud.py 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. # -*- coding: utf-8 -*-
  2. from typing import Sequence
  3. from app.core.base_crud import CRUDBase
  4. from ..auth.schema import AuthSchema
  5. from .model import ParamsModel
  6. from .schema import ParamsCreateSchema, ParamsUpdateSchema
  7. class ParamsCRUD(CRUDBase[ParamsModel, ParamsCreateSchema, ParamsUpdateSchema]):
  8. """配置管理数据层"""
  9. def __init__(self, auth: AuthSchema) -> None:
  10. """
  11. 初始化配置CRUD
  12. 参数:
  13. - auth (AuthSchema): 认证信息模型
  14. """
  15. self.auth = auth
  16. super().__init__(model=ParamsModel, auth=auth)
  17. async def get_obj_by_id_crud(self, id: int, preload: list | None = None) -> ParamsModel | None:
  18. """
  19. 获取配置管理型详情
  20. 参数:
  21. - id (int): 配置管理型ID
  22. - preload (list | None): 预加载关系,未提供时使用模型默认项
  23. 返回:
  24. - ParamsModel | None: 配置管理型模型实例
  25. """
  26. return await self.get(id=id, preload=preload)
  27. async def get_obj_by_key_crud(self, key: str, preload: list | None = None) -> ParamsModel | None:
  28. """
  29. 根据key获取配置管理型详情
  30. 参数:
  31. - key (str): 配置管理型key
  32. - preload (list | None): 预加载关系,未提供时使用模型默认项
  33. 返回:
  34. - ParamsModel | None: 配置管理型模型实例
  35. """
  36. return await self.get(config_key=key, preload=preload)
  37. async def get_obj_list_crud(self, search: dict | None = None, order_by: list | None = None, preload: list | None = None) -> Sequence[ParamsModel]:
  38. """
  39. 获取配置管理型列表
  40. 参数:
  41. - search (dict | None): 查询参数对象。
  42. - order_by (list | None): 排序参数列表。
  43. - preload (list | None): 预加载关系,未提供时使用模型默认项
  44. 返回:
  45. - Sequence[ParamsModel]: 配置管理型模型实例列表
  46. """
  47. return await self.list(search=search, order_by=order_by, preload=preload)
  48. async def create_obj_crud(self, data: ParamsCreateSchema) -> ParamsModel | None:
  49. """
  50. 创建配置管理型
  51. 参数:
  52. - data (ParamsCreateSchema): 创建配置管理型负载模型
  53. 返回:
  54. - ParamsModel | None: 配置管理型模型实例
  55. """
  56. return await self.create(data=data)
  57. async def update_obj_crud(self, id: int, data: ParamsUpdateSchema) -> ParamsModel | None:
  58. """
  59. 更新配置管理型
  60. 参数:
  61. - id (int): 配置管理型ID
  62. - data (ParamsUpdateSchema): 更新配置管理型负载模型
  63. 返回:
  64. - ParamsModel | None: 配置管理型模型实例
  65. """
  66. return await self.update(id=id, data=data)
  67. async def delete_obj_crud(self, ids: list[int]) -> None:
  68. """
  69. 删除配置管理型
  70. 参数:
  71. - ids (list[int]): 配置管理型ID列表
  72. 返回:
  73. - None
  74. """
  75. return await self.delete(ids=ids)