"""应用 数据库表"""
import uuid
from datetime import UTC, datetime
from enum import Enum as PyEnum
from typing import Any, ClassVar
from sqlalchemy import BigInteger, Boolean, DateTime, Enum, ForeignKey, Index, String
from sqlalchemy.dialects.postgresql import UUID
from sqlalchemy.orm import Mapped, mapped_column
from .base import Base
class AppType(str, PyEnum):
"""应用中心应用类型"""
FLOW = "flow"
AGENT = "agent"
class PermissionType(str, PyEnum):
"""权限类型"""
PROTECTED = "protected"
PUBLIC = "public"
PRIVATE = "private"
class App(Base):
"""应用"""
__tablename__ = "framework_app"
name: Mapped[str] = mapped_column(String(255), nullable=False)
"""应用名称"""
description: Mapped[str] = mapped_column(String(2000), nullable=False)
"""应用描述"""
authorId: Mapped[str] = mapped_column(String(50), nullable=False)
"""应用作者ID"""
appType: Mapped[AppType] = mapped_column(Enum(AppType), nullable=False)
"""应用类型"""
id: Mapped[uuid.UUID] = mapped_column(UUID(as_uuid=True), primary_key=True, default_factory=uuid.uuid4)
"""应用ID"""
updatedAt: Mapped[datetime] = mapped_column(
DateTime(timezone=True),
default_factory=lambda: datetime.now(tz=UTC),
onupdate=lambda: datetime.now(tz=UTC),
index=True,
nullable=False,
)
"""应用更新时间"""
isPublished: Mapped[bool] = mapped_column(Boolean, default=False, nullable=False)
"""是否发布"""
permission: Mapped[PermissionType] = mapped_column(
Enum(PermissionType), default=PermissionType.PUBLIC, nullable=False,
)
"""权限类型"""
idx_published_updated_at: ClassVar[Index] = Index("idx_published_updated_at", "isPublished", "updatedAt")
idx_author_id_name: ClassVar[Index] = Index("idx_author_id_name", "authorId", "id", "name")
__table_args__: ClassVar[tuple[Any, ...]] = (
idx_published_updated_at,
idx_author_id_name,
{"extend_existing": True},
)
class AppACL(Base):
"""应用权限"""
__tablename__ = "framework_app_acl"
appId: Mapped[uuid.UUID] = mapped_column(UUID(as_uuid=True), ForeignKey("framework_app.id"), primary_key=True)
"""关联的应用ID"""
userId: Mapped[str] = mapped_column(String(50), ForeignKey("framework_user.id"), nullable=False, index=True)
"""用户ID"""
action: Mapped[str] = mapped_column(String(255), default="", index=True, nullable=False)
"""操作类型(读/写)"""
class AppHashes(Base):
"""应用哈希"""
__tablename__ = "framework_app_hashes"
id: Mapped[int] = mapped_column(BigInteger, primary_key=True, autoincrement=True, init=False)
"""主键ID"""
appId: Mapped[uuid.UUID] = mapped_column(UUID(as_uuid=True), ForeignKey("framework_app.id"), nullable=False)
"""关联的应用ID"""
filePath: Mapped[str] = mapped_column(String(255), nullable=False)
"""文件路径"""
hash: Mapped[str] = mapped_column(String(255), nullable=False)
"""哈希值"""
class AppMCP(Base):
"""App使用MCP情况"""
__tablename__ = "framework_app_mcp"
appId: Mapped[uuid.UUID] = mapped_column(
UUID(as_uuid=True),
ForeignKey("framework_app.id"),
primary_key=True,
nullable=False,
)
"""关联的应用ID"""
mcpId: Mapped[str] = mapped_column(
String(255),
ForeignKey("framework_mcp.id"),
primary_key=True,
nullable=False,
)
"""关联的MCP服务ID"""
createdAt: Mapped[datetime] = mapped_column(
DateTime(timezone=True),
default_factory=lambda: datetime.now(tz=UTC),
nullable=False,
index=True,
)
"""创建时间"""