跳转至

迁移指南

rpc → use_case 重构(当前版本)

RPC 模块已全面重构为 UseCase 模式。主要变化:

旧名称 新名称
RpcService UseCaseService
create_rpc_mcp_server create_use_case_mcp_server
create_rpc_voyager create_use_case_voyager
RpcVoyager UseCaseVoyager

MCP 工具变化

从三层改为四层,增加 list_apps 层支持多应用管理:

旧工具 新工具
list_services() list_apps()list_services(app_name)
describe_service(service_name) describe_service(app_name, service_name)
call_rpc(service_name, method_name, params) call_use_case(app_name, service_name, method_name, params)

代码迁移

# Before (rpc)
from sqlmodel_nexus.rpc import RpcService, create_rpc_mcp_server

class SprintService(RpcService):
    ...

mcp = create_rpc_mcp_server(
    services=[SprintService, TaskService],
    name="Project API",
)

# After (use_case)
from sqlmodel_nexus.use_case import UseCaseService, UseCaseAppConfig, create_use_case_mcp_server

class SprintService(UseCaseService):
    ...

mcp = create_use_case_mcp_server(
    apps=[
        UseCaseAppConfig(
            name="project",
            services=[SprintService, TaskService],
            description="Project management",
        ),
    ],
    name="Project UseCase API",
)

新功能

  • 多应用管理:通过 UseCaseAppConfig 组织多个应用
  • FromContext:支持从 MCP 上下文注入参数
  • 大小写不敏感查找:app_name 查找不区分大小写

1.3.x → 1.4.0: RpcServiceConfig 移除(历史)

create_rpc_mcp_servercreate_rpc_voyager 不再接受 RpcServiceConfig 配置字典,直接传 RpcService 子类列表。

# Before (1.3.x)
from sqlmodel_nexus import RpcServiceConfig, create_rpc_mcp_server

mcp = create_rpc_mcp_server(
    services=[
        RpcServiceConfig(name="task", service=TaskService, description="..."),
        RpcServiceConfig(name="sprint", service=SprintService, description="..."),
    ],
)

# After (1.4.0)
from sqlmodel_nexus import create_rpc_mcp_server

mcp = create_rpc_mcp_server(
    services=[TaskService, SprintService],
)

1.3.2 → 1.3.3: Loader(str) 移除

Loader('relationship_name') 字符串查找模式已移除。

# Before (1.3.2)
def resolve_owner(self, loader=Loader("owner")):
    return loader.load(self.owner_id)

# After (1.3.3) — 使用 DataLoader 类或异步函数
def resolve_owner(self, loader=Loader(UserLoader)):
    return loader.load(self.owner_id)

注意:隐式自动加载已覆盖常见场景。当字段名匹配关系且类型兼容时,不需要手写 resolve_* 方法。

class TaskDTO(DefineSubset):
    __subset__ = (Task, ("id", "title", "owner_id"))
    owner: UserDTO | None = None   # 自动加载,无需 resolve_*