mirror of
https://github.com/fastapi-practices/fastapi_best_architecture.git
synced 2025-08-18 06:42:51 +08:00
30 lines
1.2 KiB
Python
30 lines
1.2 KiB
Python
#!/usr/bin/env python3
|
||
# -*- coding: utf-8 -*-
|
||
from sqlalchemy import String
|
||
from sqlalchemy.dialects.mysql import LONGTEXT
|
||
from sqlalchemy.orm import Mapped, mapped_column, relationship
|
||
|
||
from backend.app.models.base import Base, id_key
|
||
from backend.app.models.sys_role_menu import sys_role_menu
|
||
from backend.app.models.sys_user_role import sys_user_role
|
||
|
||
|
||
class Role(Base):
|
||
"""角色表"""
|
||
|
||
__tablename__ = 'sys_role'
|
||
|
||
id: Mapped[id_key] = mapped_column(init=False)
|
||
name: Mapped[str] = mapped_column(String(20), unique=True, comment='角色名称')
|
||
data_scope: Mapped[int | None] = mapped_column(default=2, comment='权限范围(1:全部数据权限 2:自定义数据权限)')
|
||
status: Mapped[int] = mapped_column(default=1, comment='角色状态(0停用 1正常)')
|
||
remark: Mapped[str | None] = mapped_column(LONGTEXT, default=None, comment='备注')
|
||
# 角色用户多对多
|
||
users: Mapped[list['User']] = relationship( # noqa: F821
|
||
init=False, secondary=sys_user_role, back_populates='roles'
|
||
)
|
||
# 角色菜单多对多
|
||
menus: Mapped[list['Menu']] = relationship( # noqa: F821
|
||
init=False, secondary=sys_role_menu, back_populates='roles'
|
||
)
|