model.py 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. from typing import TYPE_CHECKING
  2. from sqlalchemy import ForeignKey, Integer, String
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from app.common.enums import PermissionFilterStrategy
  5. from app.core.base_model import ModelMixin
  6. if TYPE_CHECKING:
  7. from app.api.v1.module_system.role.model import RoleModel
  8. from app.api.v1.module_system.user.model import UserModel
  9. class DeptModel(ModelMixin):
  10. """
  11. 部门模型
  12. """
  13. __tablename__: str = "sys_dept"
  14. __table_args__: dict[str, str] = {"comment": "部门表"}
  15. __loader_options__: list[str] = []
  16. __permission_strategy__: PermissionFilterStrategy = PermissionFilterStrategy.DEPT_BASED
  17. name: Mapped[str] = mapped_column(String(64), nullable=False, comment="部门名称")
  18. order: Mapped[int] = mapped_column(Integer, nullable=False, default=999, comment="显示排序")
  19. code: Mapped[str] = mapped_column(
  20. String(16), nullable=False, unique=True, comment="部门编码"
  21. )
  22. leader: Mapped[str | None] = mapped_column(String(32), default=None, comment="部门负责人")
  23. phone: Mapped[str | None] = mapped_column(String(11), default=None, comment="手机")
  24. email: Mapped[str | None] = mapped_column(String(64), default=None, comment="邮箱")
  25. # 树形结构字段
  26. parent_id: Mapped[int | None] = mapped_column(
  27. Integer,
  28. ForeignKey("sys_dept.id", ondelete="SET NULL", onupdate="CASCADE"),
  29. default=None,
  30. index=True,
  31. comment="父级部门ID",
  32. )
  33. # 关联关系
  34. parent: Mapped["DeptModel | None"] = relationship(
  35. back_populates="children",
  36. remote_side="DeptModel.id",
  37. foreign_keys=[parent_id],
  38. uselist=False,
  39. )
  40. children: Mapped[list["DeptModel"]] = relationship(
  41. back_populates="parent", foreign_keys=[parent_id], lazy="selectin"
  42. )
  43. roles: Mapped[list["RoleModel"]] = relationship(
  44. secondary="sys_role_depts", back_populates="depts", lazy="selectin"
  45. )
  46. users: Mapped[list["UserModel"]] = relationship(
  47. back_populates="dept",
  48. foreign_keys="UserModel.dept_id",
  49. lazy="selectin",
  50. )