model.py 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  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 MappedBase, ModelMixin
  6. if TYPE_CHECKING:
  7. from app.api.v1.module_system.dept.model import DeptModel
  8. from app.api.v1.module_system.menu.model import MenuModel
  9. from app.api.v1.module_system.user.model import UserModel
  10. class RoleMenusModel(MappedBase):
  11. """
  12. 角色菜单关联表
  13. 定义角色与菜单的多对多关系,用于权限控制
  14. """
  15. __tablename__: str = "sys_role_menus"
  16. __table_args__: dict[str, str] = {"comment": "角色菜单关联表"}
  17. role_id: Mapped[int] = mapped_column(
  18. Integer,
  19. ForeignKey("sys_role.id", ondelete="CASCADE", onupdate="CASCADE"),
  20. primary_key=True,
  21. comment="角色ID",
  22. )
  23. menu_id: Mapped[int] = mapped_column(
  24. Integer,
  25. ForeignKey("sys_menu.id", ondelete="CASCADE", onupdate="CASCADE"),
  26. primary_key=True,
  27. comment="菜单ID",
  28. )
  29. class RoleDeptsModel(MappedBase):
  30. """
  31. 角色部门关联表
  32. 定义角色与部门的多对多关系,用于数据权限控制
  33. 仅当角色的data_scope=5(自定义数据权限)时使用此表
  34. """
  35. __tablename__: str = "sys_role_depts"
  36. __table_args__: dict[str, str] = {"comment": "角色部门关联表"}
  37. role_id: Mapped[int] = mapped_column(
  38. Integer,
  39. ForeignKey("sys_role.id", ondelete="CASCADE", onupdate="CASCADE"),
  40. primary_key=True,
  41. comment="角色ID",
  42. )
  43. dept_id: Mapped[int] = mapped_column(
  44. Integer,
  45. ForeignKey("sys_dept.id", ondelete="CASCADE", onupdate="CASCADE"),
  46. primary_key=True,
  47. comment="部门ID",
  48. )
  49. class RoleModel(ModelMixin):
  50. """
  51. 角色模型
  52. 角色列表只显示当前用户绑定的角色
  53. """
  54. __tablename__: str = "sys_role"
  55. __table_args__: dict[str, str] = {"comment": "角色表"}
  56. __loader_options__: list[str] = ["menus", "depts"]
  57. __permission_strategy__: PermissionFilterStrategy = PermissionFilterStrategy.USER_ROLE
  58. name: Mapped[str] = mapped_column(String(64), nullable=False, comment="角色名称")
  59. code: Mapped[str] = mapped_column(
  60. String(16), nullable=False, unique=True, comment="角色编码"
  61. )
  62. order: Mapped[int] = mapped_column(Integer, nullable=False, default=999, comment="显示排序")
  63. data_scope: Mapped[int] = mapped_column(
  64. Integer,
  65. default=1,
  66. nullable=False,
  67. comment="数据权限范围(1:仅本人 2:本部门 3:本部门及以下 4:全部 5:自定义)",
  68. )
  69. menus: Mapped[list["MenuModel"]] = relationship(
  70. secondary="sys_role_menus",
  71. back_populates="roles",
  72. lazy="selectin",
  73. order_by="MenuModel.order",
  74. )
  75. depts: Mapped[list["DeptModel"]] = relationship(
  76. secondary="sys_role_depts", back_populates="roles", lazy="selectin"
  77. )
  78. users: Mapped[list["UserModel"]] = relationship(
  79. secondary="sys_user_roles", back_populates="roles", lazy="selectin"
  80. )