跳转到内容

Plugin SDK 迁移

OpenClaw 已从一个广泛的向后兼容层转变为一个具有重点、文档化导入的现代插件架构。如果您的插件是在新架构之前构建的,本指南将帮助您进行迁移。

旧的插件系统提供了两个开放的面,允许插件从单个入口点导入它们需要的任何内容:

  • openclaw/plugin-sdk/compat - 单个导入项,它重新导出了数十个辅助函数。引入它的目的是在构建新插件架构的同时,使基于旧 Hook 的插件能够继续工作。
  • openclaw/plugin-sdk/infra-runtime - 一个广泛的运行时辅助函数聚合桶,它混合了系统事件、心跳状态、传递队列、获取/代理辅助函数、文件辅助函数、审批类型以及不相关的实用程序。
  • openclaw/plugin-sdk/config-runtime - 一个广泛的配置兼容性聚合桶,在迁移期间,它仍然包含已弃用的直接加载/写入辅助函数。
  • openclaw/extension-api - 一座桥梁,使插件能够直接访问主机端辅助函数,例如嵌入式代理运行器。
  • api.registerEmbeddedExtensionFactory(...) - 一个已移除的仅限 Pi 的捆绑扩展 Hook,它可以观察嵌入式运行器事件,例如 tool_result

这些广泛的导入接口现已弃用。它们在运行时仍然有效,但新插件不得使用它们,现有插件应在下一个主要版本将其移除之前进行迁移。仅限 Pi 的嵌入式扩展工厂注册 API 已被移除;请改用工具结果中间件。

OpenClaw 不会在引入替换项的同一更改中移除或重新解释已记录的插件行为。破坏性的合同变更必须先经过兼容性适配器、诊断、文档和弃用窗口。这适用于 SDK 导入、清单字段、设置 API、hook 和运行时注册行为。

旧方法导致了以下问题:

  • 启动缓慢 - 导入一个辅助函数会加载数十个不相关的模块
  • 循环依赖 - 宽泛的重新导出使得创建导入循环变得容易
  • 不清晰的 API 表面 - 无法区分哪些导出是稳定的,哪些是内部的

现代插件 SDK 解决了此问题:每个导入路径 (openclaw/plugin-sdk/\<subpath\>) 都是一个小型、自包含的模块,具有明确的目的且有文档记录的约定。

针对捆绑渠道的旧版提供商便利接口也已消失。特定品牌的辅助函数接口是私有 mono-repo 快捷方式,并非稳定的插件约定。请改用狭窄的通用 SDK 子路径。在捆绑插件工作区内,将提供商拥有的辅助函数保留在该插件自己的 api.tsruntime-api.ts 中。

当前的捆绑提供商示例:

  • Anthropic 将 Claude 专用的流辅助函数保留在其自己的 api.ts / contract-api.ts 接口中
  • OpenAI 将提供商构建器、默认模型辅助函数和实时提供商构建器保留在其自己的 api.ts
  • OpenRouter 将提供商构建器和引导/配置辅助函数保留在其自己的 api.ts

实时语音、电话、会议和浏览器 Talk 代码正从本地轮次记账迁移到由 openclaw/plugin-sdk/realtime-voice 导出的共享 Talk 会话控制器。新控制器拥有通用的 Talk 事件包封、活动轮次状态、捕获状态、输出音频状态、近期事件历史以及过期轮次拒绝功能。提供商插件应继续拥有特定于厂商的实时会话;Surface 插件应继续拥有捕获、播放、电话和会议的特有行为。

此 Talk 迁移是有意彻底破坏性的:

  1. 将共享控制器/运行时原语保留在 plugin-sdk/realtime-voice 中。
  2. 将捆绑的表面迁移到共享控制器上:浏览器中继、 托管房间切换、语音通话实时、语音通话流式 STT、Google Meet 实时和原生按键通话。
  3. 使用最终的 RPCtalk.session.*talk.client.*API API 替换旧的 Talk RPC 系列。
  4. 在 Gateway Gateway(网关)hello-ok.features.events 中通告一个实时 Talk 事件渠道:talk.event
  5. 删除旧的实时 HTTP 端点和任何请求时指令 覆盖路径。

新代码不应直接调用 createTalkEventSequencer(...),除非它正在实现低级适配器或测试装置。首选共享控制器,这样就不能在没有轮次 ID 的情况下发出轮次范围的事件,过期的 turnEnd / turnCancel 调用无法清除较新的活动轮次,并且输出音频生命周期事件在电话、会议、浏览器中继、托管房间切换和原生 Talk 客户端之间保持一致。

目标公共 API 形状为:

// Gateway-owned Talk session API.
await gateway.request("talk.session.create", {
mode: "realtime",
transport: "gateway-relay",
brain: "agent-consult",
sessionKey: "main",
});
await gateway.request("talk.session.appendAudio", { sessionId, audioBase64 });
await gateway.request("talk.session.cancelOutput", { sessionId, reason: "barge-in" });
await gateway.request("talk.session.submitToolResult", {
sessionId,
callId,
result: { status: "working" },
options: { willContinue: true },
});
await gateway.request("talk.session.submitToolResult", {
sessionId,
callId,
result: { status: "already_delivered" },
options: { suppressResponse: true },
});
await gateway.request("talk.session.submitToolResult", { sessionId, callId, result });
await gateway.request("talk.session.close", { sessionId });
// Client-owned provider session API.
await gateway.request("talk.client.create", {
mode: "realtime",
transport: "webrtc",
brain: "agent-consult",
sessionKey: "main",
});
await gateway.request("talk.client.toolCall", { sessionKey, callId, name, args });

浏览器拥有的 WebRTC/提供商-WebSocket 会话使用 talk.client.createGateway(网关),因为浏览器拥有提供商协商和媒体传输,而 Gateway 拥有凭据、指令和工具策略。talk.session.*Gateway(网关) 是 Gateway 管理的通用 Surface,用于网关中继实时、网关中继转录以及托管房间原生 STT/TTS 会话。

将实时选择器放置在 talk.provider / talk.providers 旁边的旧版配置应使用 openclaw doctor --fix 进行修复;运行时 Talk 不会将语音/TTS 提供商配置重新解释为实时提供商配置。

支持的 talk.session.create 组合有意设置得很少:

模式传输大脑所有者备注
realtimegateway-relayagent-consultGateway(网关)通过 Gateway(网关) 桥接的全双工提供商音频;工具调用通过 agent-consult 工具路由。
transcriptiongateway-relaynoneGateway(网关)仅限流式 STT;调用者发送输入音频并接收转录事件。
stt-ttsmanaged-roomagent-consult原生/客户端房间按住通话和对讲机式房间,由客户端拥有采集/回放,由Gateway(网关)拥有轮次状态。
stt-ttsmanaged-roomdirect-tools原生/客户端房间仅限管理员房间模式,适用于直接执行Gateway(网关)工具操作的可信第一方界面。

已移除的方法映射:

talk.realtime.sessiontalk.client.create
talk.realtime.toolCalltalk.client.toolCall
talk.realtime.relayAudiotalk.session.appendAudio
talk.realtime.relayCanceltalk.session.cancelOutputtalk.session.cancelTurn
talk.realtime.relayToolResulttalk.session.submitToolResult
talk.realtime.relayStoptalk.session.close
talk.transcription.sessiontalk.session.create({ mode: "transcription" })
talk.transcription.relayAudiotalk.session.appendAudio
talk.transcription.relayCanceltalk.session.cancelTurn
talk.transcription.relayStoptalk.session.close
talk.handoff.createtalk.session.create({ transport: "managed-room" })
talk.handoff.jointalk.session.join
talk.handoff.revoketalk.session.close

统一控制词汇表也特意设计得很窄:

方法适用于约定
talk.session.appendAudiorealtime/gateway-relay, transcription/gateway-relay将 base64 PCM 音频块追加到属于同一Gateway(网关)连接的提供商会话。
talk.session.startTurnstt-tts/managed-room开始托管房间的用户轮次。
talk.session.endTurnstt-tts/managed-room在过期轮次验证后结束当前轮次。
talk.session.cancelTurn所有Gateway(网关)拥有的会话取消某个轮次的活跃采集/提供商/代理/TTS工作。
talk.session.cancelOutputrealtime/gateway-relay停止助手音频输出,而不必结束用户轮次。
talk.session.submitToolResultrealtime/gateway-relay完成由中继发出的提供商工具调用;传递 options.willContinue 用于临时输出,或传递 options.suppressResponse 以在无需另一个助手响应的情况下满足该调用。
talk.session.close所有统一会话停止中继会话或撤销托管房间状态,然后忘记统一会话 ID。

不要在核心中引入提供商或平台特殊情况来实现此功能。 核心拥有 Talk 会话语义。提供商插件拥有供应商会话设置。 Voice-call 和 Google Meet 拥有电话/会议适配器。浏览器和原生 应用拥有设备捕获/播放 UX。

对于外部插件,兼容性工作遵循以下顺序:

  1. 添加新合约
  2. 通过兼容性适配器保持旧行为的连接
  3. 发出诊断或警告,指出旧路径和替换路径
  4. 在测试中覆盖两条路径
  5. 记录弃用和迁移路径
  6. 仅在宣布的迁移窗口之后移除,通常是在主要版本中

维护者可以使用 pnpm plugins:boundary-report 审核当前的迁移队列。使用 pnpm plugins:boundary-report:summary 获取紧凑计数,使用 --owner <id> 针对单个插件或兼容性负责人,以及 pnpm plugins:boundary-report:ci 当 CI 门控应在过期的兼容性记录、跨负责人保留的 SDK 导入或未使用的保留 SDK 子路径上失败时。该报告按移除日期对已弃用的兼容性记录进行分组,统计本地代码/文档引用,公开跨负责人保留的 SDK 导入,并总结私有内存主机 SDK 桥,从而使兼容性清理保持明确,而不是依赖临时搜索。保留的 SDK 子路径必须跟踪所有者的使用情况;未使用的保留辅助导出应从公共 SDK 中删除。

如果仍然接受清单字段,插件作者可以继续使用它,直到 文档和诊断另有说明。新代码应优先使用记录在案的 替换项,但现有插件不应在常规次要 版本中中断。

  1. 迁移运行时配置加载/写入辅助函数

    捆绑插件应停止直接调用 api.runtime.config.loadConfig()api.runtime.config.writeConfigFile(...)。首选已传递到活动调用路径中的配置。需要当前进程快照的长期处理程序可以使用 api.runtime.config.current()。长期代理工具应在 execute 中使用工具上下文的 ctx.getRuntimeConfig(),以便在配置写入之前创建的工具仍然能看到刷新后的运行时配置。

    配置写入必须通过事务辅助函数进行,并选择写入后策略:

    await api.runtime.config.mutateConfigFile({
    afterWrite: { mode: "auto" },
    mutate(draft) {
    draft.plugins ??= {};
    },
    });

    当调用者知道更改需要彻底重启网关时,请使用 afterWrite: { mode: "restart", reason: "..." };仅当调用者拥有后续操作并有意想要抑制重载规划器时,才使用 afterWrite: { mode: "none", reason: "..." }。变更结果包含用于测试和记录的带类型 followUp 摘要;网关仍然负责应用或安排重启。loadConfigwriteConfigFile 作为已弃用的兼容性辅助函数保留,用于迁移期间的外部插件,并会使用 runtime-config-load-write 兼容性代码发出一次警告。捆绑插件和仓库运行时代码受 pnpm check:deprecated-api-usagepnpm check:no-runtime-action-load-config 中的扫描器护栏保护:新的生产插件使用将彻底失败,直接配置写入将失败,网关服务器方法必须使用请求运行时快照,运行时渠道发送/操作/客户端辅助函数必须从其边界接收配置,且长期运行时模块不允许任何环境 loadConfig() 调用。

    新插件代码还应避免导入广泛的 openclaw/plugin-sdk/config-runtime 兼容性桶。使用与任务匹配的狭窄 SDK 子路径:

    需求导入
    配置类型,例如 OpenClawConfigopenclaw/plugin-sdk/config-contracts
    已加载的配置断言和插件条目配置查找openclaw/plugin-sdk/plugin-config-runtime
    当前运行时快照读取openclaw/plugin-sdk/runtime-config-snapshot
    配置写入openclaw/plugin-sdk/config-mutation
    会话存储辅助函数openclaw/plugin-sdk/session-store-runtime
    Markdown 表格配置openclaw/plugin-sdk/markdown-table-runtime
    组策略运行时辅助函数openclaw/plugin-sdk/runtime-group-policy
    密钥输入解析openclaw/plugin-sdk/secret-input-runtime
    模型/会话覆盖openclaw/plugin-sdk/model-session-runtime

    捆绑插件及其测试针对广泛的桶进行了扫描器保护,以确保导入和模拟保持在其所需行为的本地。广泛的桶仍然存在以用于外部兼容性,但新代码不应依赖于它。

  2. 将 Pi 工具结果扩展迁移到中间件

    捆绑插件必须将仅限 Pi 的 api.registerEmbeddedExtensionFactory(...) 工具结果处理程序替换为 运行时无关的中间件。

    // Pi and Codex runtime dynamic tools
    api.registerAgentToolResultMiddleware(async (event) => {
    return compactToolResult(event);
    }, {
    runtimes: ["pi", "codex"],
    });

    同时更新插件清单:

    {
    "contracts": {
    "agentToolResultMiddleware": ["pi", "codex"]
    }
    }

    外部插件无法注册工具结果中间件,因为它可以在模型看到之前 重写高信任度工具输出。

  3. 将审批原生处理程序迁移到能力事实

    具备审批能力的渠道插件现在通过 approvalCapability.nativeRuntime 加上共享的运行时上下文注册表来 暴露原生审批行为。

    主要变更:

    • approvalCapability.nativeRuntime 替换 approvalCapability.handler.loadRuntime(...)
    • 将审批特定的身份验证/交付从旧版 plugin.auth / plugin.approvals 连接转移到 approvalCapability
    • ChannelPlugin.approvals 已从公共渠道插件 契约中移除;将交付/原生/渲染字段移动到 approvalCapability
    • plugin.authBolt 仅保留用于渠道登录/登出流程;核心 不再读取那里的审批身份验证挂钩
    • 通过 openclaw/plugin-sdk/channel-runtime-context 注册渠道拥有的运行时对象, 例如客户端、令牌或 Bolt 应用
    • 请勿从原生审批处理程序发送插件拥有的重路由通知; 核心现在拥有来自实际交付结果的路由到别处通知
    • channelRuntime 传递到 createChannelManager(...) 时, 请提供真实的 createPluginRuntime().channel 接口。 部分存根将被拒绝。

    请参阅 /plugins/sdk-channel-plugins 了解当前的审批能力 布局。

  4. Windows审查 Windows 封装器的回退行为

    如果您的插件使用 openclaw/plugin-sdk/windows-spawnWindows,未解析的 Windows .cmd/.bat 封装器现在会以“封闭失败”方式处理,除非您显式传递 allowShellFallback: true

    // Before
    const program = applyWindowsSpawnProgramPolicy({ candidate });
    // After
    const program = applyWindowsSpawnProgramPolicy({
    candidate,
    // Only set this for trusted compatibility callers that intentionally
    // accept shell-mediated fallback.
    allowShellFallback: true,
    });

    如果您的调用者并非有意依赖 shell 回退机制,请勿设置 allowShellFallback,而是处理抛出的错误。

  5. 查找已弃用的导入

    在您的插件中搜索从任一已弃用接口进行的导入:

    Terminal window
    grep -r "plugin-sdk/compat" my-plugin/
    grep -r "plugin-sdk/infra-runtime" my-plugin/
    grep -r "plugin-sdk/config-runtime" my-plugin/
    grep -r "openclaw/extension-api" my-plugin/
  6. 替换为精确的导入

    旧接口中的每个导出项都映射到特定的现代导入路径:

    // Before (deprecated backwards-compatibility layer)
    import {
    createChannelReplyPipeline,
    createPluginRuntimeStore,
    resolveControlCommandGate,
    } from "openclaw/plugin-sdk/compat";
    // After (modern focused imports)
    import { createChannelReplyPipeline } from "openclaw/plugin-sdk/channel-reply-pipeline";
    import { createPluginRuntimeStore } from "openclaw/plugin-sdk/runtime-store";
    import { resolveControlCommandGate } from "openclaw/plugin-sdk/command-auth";

    对于宿主端辅助函数,请使用注入的插件运行时,而不是直接导入:

    // Before (deprecated extension-api bridge)
    import { runEmbeddedPiAgent } from "openclaw/extension-api";
    const result = await runEmbeddedPiAgent({ sessionId, prompt });
    // After (injected runtime)
    const result = await api.runtime.agent.runEmbeddedPiAgent({ sessionId, prompt });

    同样的模式适用于其他旧的桥接辅助函数:

    旧导入现代等效项
    resolveAgentDirapi.runtime.agent.resolveAgentDir
    resolveAgentWorkspaceDirapi.runtime.agent.resolveAgentWorkspaceDir
    resolveAgentIdentityapi.runtime.agent.resolveAgentIdentity
    resolveThinkingDefaultapi.runtime.agent.resolveThinkingDefault
    resolveAgentTimeoutMsapi.runtime.agent.resolveAgentTimeoutMs
    ensureAgentWorkspaceapi.runtime.agent.ensureAgentWorkspace
    会话 store helpersapi.runtime.agent.session.*
  7. 替换广泛的 infra-runtime 导入

    为了保持外部兼容性,openclaw/plugin-sdk/infra-runtime 仍然存在,但新代码应该导入其真正需要的聚焦的辅助接口:

    需求导入
    系统事件队列辅助openclaw/plugin-sdk/system-event-runtime
    心跳唤醒、事件和可见性辅助openclaw/plugin-sdk/heartbeat-runtime
    待处理投递队列排空openclaw/plugin-sdk/delivery-queue-runtime
    频道活动遥测openclaw/plugin-sdk/channel-activity-runtime
    内存去重缓存openclaw/plugin-sdk/dedupe-runtime
    安全的本地文件/媒体路径辅助openclaw/plugin-sdk/file-access-runtime
    调度器感知的获取openclaw/plugin-sdk/runtime-fetch
    代理和受保护的获取辅助openclaw/plugin-sdk/fetch-runtime
    SSRF 调度器策略类型openclaw/plugin-sdk/ssrf-dispatcher
    审批请求/解决类型openclaw/plugin-sdk/approval-runtime
    审批回复负载和命令辅助openclaw/plugin-sdk/approval-reply-runtime
    错误格式化辅助openclaw/plugin-sdk/error-runtime
    传输就绪等待openclaw/plugin-sdk/transport-ready-runtime
    安全令牌辅助openclaw/plugin-sdk/secure-random-runtime
    有界异步任务并发openclaw/plugin-sdk/concurrency-runtime
    数值强制转换openclaw/plugin-sdk/number-runtime
    进程本地异步锁openclaw/plugin-sdk/async-lock-runtime
    文件锁openclaw/plugin-sdk/file-lock

    捆绑插件针对 infra-runtime 进行了扫描程序保护,因此代码库代码不会退回到广泛的总体导入中。

  8. 迁移渠道路由辅助函数

    新的渠道路由代码应使用 openclaw/plugin-sdk/channel-route。 较旧的路由键和可比目标名称在迁移窗口期间保留为兼容性别名,但新插件应使用直接描述行为的路由名称:

    旧辅助函数现代辅助函数
    channelRouteIdentityKey(...)channelRouteDedupeKey(...)
    channelRouteKey(...)channelRouteCompactKey(...)
    ComparableChannelTargetChannelRouteParsedTarget
    resolveComparableTargetForChannel(...)resolveRouteTargetForChannel(...)
    resolveComparableTargetForLoadedChannel(...)resolveRouteTargetForLoadedChannel(...)
    comparableChannelTargetsMatch(...)channelRouteTargetsMatchExact(...)
    comparableChannelTargetsShareRoute(...)channelRouteTargetsShareConversation(...)

    现代路由辅助函数在原生审批、回复抑制、入站去重、定时传送和会话路由之间统一规范化 { channel, to, accountId, threadId }。如果你的插件拥有自定义目标语法,请使用 resolveChannelRouteTargetWithParser(...) 将该解析器适配到相同的路由目标合约。

  9. 构建并测试

    Terminal window
    pnpm build
    pnpm test -- my-plugin/
通用导入路径表

| 导入路径 | 用途 | 主要导出 | | --- | --- | --- | | plugin-sdk/plugin-entry | 规范化插件入口助手 | definePluginEntry | | plugin-sdk/core | 用于渠道入口定义/构建器的旧版通用重新导出 | defineChannelPluginEntrycreateChatChannelPlugin | | plugin-sdk/config-schema | 根配置架构导出 | OpenClawSchema | | plugin-sdk/provider-entry | 单提供商入口助手 | defineSingleProviderPluginEntry | | plugin-sdk/channel-core | 专注的渠道入口定义和构建器 | defineChannelPluginEntrydefineSetupPluginEntrycreateChatChannelPlugincreateChannelPluginBase | | plugin-sdk/setup | 共享设置向导助手 | 设置翻译器、允许列表提示、设置状态构建器 | | plugin-sdk/setup-runtime | 设置时运行时助手 | createSetupTranslator、导入安全的设置补丁适配器、查找备注助手、promptResolvedAllowFromsplitSetupEntries、委托设置代理 | | plugin-sdk/setup-adapter-runtime | 已弃用的设置适配器别名 | 使用 plugin-sdk/setup-runtime | | plugin-sdk/setup-tools | 设置工具助手 | formatCliCommanddetectBinaryextractArchiveresolveBrewExecutableformatDocsLinkCONFIG_DIR | | plugin-sdk/account-core | 多账户助手 | 账户列表/配置/操作门控助手 | | plugin-sdk/account-id | 账户ID助手 | DEFAULT_ACCOUNT_ID、账户ID规范化 | | plugin-sdk/account-resolution | 账户查找助手 | 账户查找 + 默认回退助手 | | plugin-sdk/account-helpers | 精简账户助手 | 账户列表/账户操作助手 | | plugin-sdk/channel-setup | 设置向导适配器 | createOptionalChannelSetupSurfacecreateOptionalChannelSetupAdaptercreateOptionalChannelSetupWizard,以及 DEFAULT_ACCOUNT_IDcreateTopLevelChannelDmPolicysetSetupChannelEnabledsplitSetupEntries | | plugin-sdk/channel-pairing | 私信配对原语 | createChannelPairingController | | plugin-sdk/channel-reply-pipeline | 回复前缀、输入状态和源交付连接 | createChannelReplyPipelineresolveChannelSourceReplyDeliveryMode | | plugin-sdk/channel-config-helpers | 配置适配器工厂和私信访问助手 | createHybridChannelConfigAdapterresolveChannelDmAccessresolveChannelDmAllowFromresolveChannelDmPolicynormalizeChannelDmPolicynormalizeLegacyDmAliases | | plugin-sdk/channel-config-schema | 配置架构构建器 | 仅包含共享渠道配置架构原语和通用构建器 | | plugin-sdk/bundled-channel-config-schema | 捆绑配置架构 | 仅限 OpenClaw 维护的捆绑插件;新插件必须定义插件本地架构 | | plugin-sdk/channel-config-schema-legacy | 已弃用的捆绑配置架构 | 仅为兼容性别名;对于维护的捆绑插件,请使用 plugin-sdk/bundled-channel-config-schema | | plugin-sdk/telegram-command-config | Telegram 命令配置助手 | 命令名称规范化、描述裁剪、重复/冲突验证 | | plugin-sdk/channel-policy | 群组/私信策略解析 | resolveChannelGroupRequireMention | | plugin-sdk/channel-lifecycle | 账户状态和草稿流生命周期助手 | createAccountStatusSink、草稿预览最终化助手 | | plugin-sdk/inbound-envelope | 入站信封助手 | 共享路由 + 信封构建器助手 | | plugin-sdk/inbound-reply-dispatch | 入站回复助手 | 共享记录和分发助手 | | plugin-sdk/messaging-targets | 消息目标解析 | 目标解析/匹配助手 | | plugin-sdk/outbound-media | 出站媒体助手 | 共享出站媒体加载 | | plugin-sdk/outbound-send-deps | 出站发送依赖助手 | 轻量级 resolveOutboundSendDep 查找,无需导入完整出站运行时 | | plugin-sdk/outbound-runtime | 出站运行时助手 | 出站交付、身份/发送委托、会话、格式化和负载规划助手 | | plugin-sdk/thread-bindings-runtime | 线程绑定助手 | 线程绑定生命周期和适配器助手 | | plugin-sdk/agent-media-payload | 旧版媒体负载助手 | 用于旧版字段布局的代理媒体负载构建器 | | plugin-sdk/channel-runtime | 已弃用的兼容性填充 | 仅限旧版渠道运行时工具 | | plugin-sdk/channel-send-result | 发送结果类型 | 回复结果类型 | | plugin-sdk/runtime-store | 持久化插件存储 | createPluginRuntimeStore | | plugin-sdk/runtime | 广泛运行时助手 | 运行时/日志/备份/插件安装助手 | | plugin-sdk/runtime-env | 精简运行时环境助手 | 记录器/运行时环境、超时、重试和退避助手 | | plugin-sdk/plugin-runtime | 共享插件运行时助手 | 插件命令/钩子/http/交互助手 | | plugin-sdk/hook-runtime | 钩子管道助手 | 共享 webhook/内部钩子管道助手 | | plugin-sdk/lazy-runtime | 延迟运行时助手 | createLazyRuntimeModulecreateLazyRuntimeMethodcreateLazyRuntimeMethodBindercreateLazyRuntimeNamedExportcreateLazyRuntimeSurface | | plugin-sdk/process-runtime | 进程助手 | 共享执行助手 | | plugin-sdk/cli-runtime | CLI 运行时助手 | 命令格式化、等待、版本助手 | | plugin-sdk/gateway-runtime | Gateway(网关) 助手 | Gateway(网关) 客户端、事件循环就绪启动助手和渠道状态补丁助手 | | plugin-sdk/config-runtime | 已弃用的配置兼容性填充 | 优先使用 config-contractsplugin-config-runtimeruntime-config-snapshotconfig-mutation | | plugin-sdk/telegram-command-config | Telegram 命令助手 | 当捆绑的 Telegram 命令合约接口不可用时,提供回退稳定的 Telegram 命令验证助手 | | plugin-sdk/approval-runtime | 批准提示助手 | 执行/插件批准负载、批准能力/配置助手、原生批准路由/运行时助手以及结构化批准显示路径格式化 | | plugin-sdk/approval-auth-runtime | 批准身份验证助手 | 批准者解析、同聊操作授权 | | plugin-sdk/approval-client-runtime | 批准客户端助手 | 原生执行批准配置/过滤器助手 | | plugin-sdk/approval-delivery-runtime | 批准交付助手 | 原生批准能力/交付适配器 | | plugin-sdk/approval-gateway-runtime | 批准网关助手 | 共享批准网关解析助手 | | plugin-sdk/approval-handler-adapter-runtime | 批准适配器助手 | 用于热渠道入口点的轻量级原生批准适配器加载助手 | | plugin-sdk/approval-handler-runtime | 批准处理程序助手 | 更广泛的批准处理程序运行时助手;当适配器/网关接口足够时,优先使用它们 | | plugin-sdk/approval-native-runtime | 批准目标助手 | 原生批准目标/账户绑定助手 | | plugin-sdk/approval-reply-runtime | 批准回复助手 | 执行/插件批准回复负载助手 | | plugin-sdk/channel-runtime-context | 渠道运行时上下文助手 | 通用渠道运行时上下文注册/获取/监听助手 | | plugin-sdk/security-runtime | 安全助手 | 共享信任、私信门控、根边界文件/路径助手、外部内容和密钥收集助手 | | plugin-sdk/ssrf-policy | SSRF 策略助手 | 主机允许列表和私有网络策略助手 | | plugin-sdk/ssrf-runtime | SSRF 运行时助手 | 固定分发器、受保护获取、SSRF 策略助手 | | plugin-sdk/system-event-runtime | 系统事件助手 | enqueueSystemEventpeekSystemEventEntries | | plugin-sdk/heartbeat-runtime | 心跳助手 | 心跳唤醒、事件和可见性助手 | | plugin-sdk/delivery-queue-runtime | 交付队列助手 | drainPendingDeliveries | | plugin-sdk/channel-activity-runtime | 渠道活动助手 | recordChannelActivity | | plugin-sdk/dedupe-runtime | 去重助手 | 内存去重缓存 | | plugin-sdk/file-access-runtime | 文件访问助手 | 安全本地文件/媒体路径助手 | | plugin-sdk/transport-ready-runtime | 传输就绪助手 | waitForTransportReady | | plugin-sdk/collection-runtime | 有界缓存助手 | pruneMapToMaxSize | | plugin-sdk/diagnostic-runtime | 诊断门控助手 | isDiagnosticFlagEnabledisDiagnosticsEnabled | | plugin-sdk/error-runtime | 错误格式化助手 | formatUncaughtErrorisApprovalNotFoundError、错误图助手 | | plugin-sdk/fetch-runtime | 封装获取/代理助手 | resolveFetch、代理助手、EnvHttpProxyAgent 选项助手 | | plugin-sdk/host-runtime | 主机规范化助手 | normalizeHostnamenormalizeScpRemoteHost | | plugin-sdk/retry-runtime | 重试助手 | RetryConfigretryAsync、策略运行器 | | plugin-sdk/allow-from | 允许列表格式化 | formatAllowFromLowercase | | plugin-sdk/allowlist-resolution | 允许列表输入映射 | mapAllowlistResolutionInputs | | plugin-sdk/command-auth | 命令门控和命令接口助手 | resolveControlCommandGate、发送者授权助手、命令注册助手(包括动态参数菜单格式化) | | plugin-sdk/command-status | 命令状态/帮助渲染器 | buildCommandsMessagebuildCommandsMessagePaginatedbuildHelpMessage | | plugin-sdk/secret-input | 密钥输入解析 | 密钥输入助手 | | plugin-sdk/webhook-ingress | Webhook 请求助手 | Webhook 目标工具 | | plugin-sdk/webhook-request-guards | Webhook 正文保护助手 | 请求正文读取/限制助手 | | plugin-sdk/reply-runtime | 共享回复运行时 | 入站分发、心跳、回复规划、分块 | | plugin-sdk/reply-dispatch-runtime | 精简回复分发助手 | 最终化、提供商分发和对话标签助手 | | plugin-sdk/reply-history | 回复历史助手 | createChannelHistoryWindow;已弃用的映射助手兼容性导出,例如 buildPendingHistoryContextFromMaprecordPendingHistoryEntryclearHistoryEntriesIfEnabled | | plugin-sdk/reply-reference | 回复引用规划 | createReplyReferencePlanner | | plugin-sdk/reply-chunking | 回复分块助手 | 文本/Markdown 分块助手 | | plugin-sdk/session-store-runtime | 会话存储助手 | 存储路径 + 更新时间助手 | | plugin-sdk/state-paths | 状态路径助手 | 状态和 OAuth 目录助手 | | plugin-sdk/routing | 路由/会话密钥助手 | resolveAgentRoutebuildAgentSessionKeyresolveDefaultAgentBoundAccountId、会话密钥规范化助手 | | plugin-sdk/status-helpers | 渠道状态助手 | 渠道/账户状态摘要构建器、运行时状态默认值、问题元数据助手 | | plugin-sdk/target-resolver-runtime | 目标解析器助手 | 共享目标解析器助手 | | plugin-sdk/string-normalization-runtime | 字符串规范化助手 | Slug/字符串规范化助手 | | plugin-sdk/request-url | 请求 URL 助手 | 从类请求输入中提取字符串 URL | | plugin-sdk/run-command | 计时命令助手 | 带有规范化 stdout/stderr 的计时命令运行器 | | plugin-sdk/param-readers | 参数读取器 | 通用工具/CLI 参数读取器 | | plugin-sdk/tool-payload | 工具负载提取 | 从工具结果对象中提取规范化的负载 | | plugin-sdk/tool-send | 工具发送提取 | 从工具参数中提取规范的发送目标字段 | | plugin-sdk/temp-path | 临时路径助手 | 共享临时下载路径助手 | | plugin-sdk/logging-core | 日志记录助手 | 子系统记录器和编辑助手 | | plugin-sdk/markdown-table-runtime | Markdown 表格助手 | Markdown 表格模式助手 | | plugin-sdk/reply-payload | 消息回复类型 | 回复负载类型 | | plugin-sdk/provider-setup | 策选的本地/自托管提供商设置助手 | 自托管提供商发现/配置助手 | | plugin-sdk/self-hosted-provider-setup | 专注的 OpenAI 兼容自托管提供商设置助手 | 相同的自托管提供商发现/配置助手 | | plugin-sdk/provider-auth-runtime | 提供商运行时身份验证助手 | 运行时 API 密钥解析助手 | | plugin-sdk/provider-auth-api-key | 提供商 API 密钥设置助手 | API 密钥新手引导/配置写入助手 | | plugin-sdk/provider-auth-result | 提供商身份验证结果助手 | 标准 OAuth 身份验证结果构建器 | | plugin-sdk/provider-selection-runtime | 提供商选择助手 | 已配置或自动提供商选择以及原始提供商配置合并 | | plugin-sdk/provider-env-vars | 提供商环境变量助手 | 提供商身份验证环境变量查找助手 | | plugin-sdk/provider-model-shared | 共享提供商模型/重放助手 | ProviderReplayFamilybuildProviderReplayFamilyHooksnormalizeModelCompat、共享重放策略构建器、提供商端点助手和模型 ID 规范化助手 | | plugin-sdk/provider-catalog-shared | 共享提供商目录助手 | findCatalogTemplatebuildSingleProviderApiKeyCatalogbuildManifestModelProviderConfigsupportsNativeStreamingUsageCompatapplyProviderNativeStreamingUsageCompat | | plugin-sdk/provider-onboard | 提供商新手引导补丁 | 新手引导配置助手 | | plugin-sdk/provider-http | 提供商 HTTP 助手 | 通用提供商 HTTP/端点能力助手,包括音频转录多部分表单助手 | | plugin-sdk/provider-web-fetch | 提供商网页获取助手 | 网页获取提供商注册/缓存助手 | | plugin-sdk/provider-web-search-config-contract | 提供商网页搜索配置助手 | 针对不需要插件启用接线的提供商的精简网页搜索配置/凭证助手 | | plugin-sdk/provider-web-search-contract | 提供商网页搜索合约助手 | 精简网页搜索配置/凭证合约助手,例如 createWebSearchProviderContractFieldsenablePluginInConfigresolveProviderWebSearchPluginConfig 以及作用域凭证设置器/获取器 | | plugin-sdk/provider-web-search | 提供商网页搜索助手 | 网页搜索提供商注册/缓存/运行时助手 | | plugin-sdk/provider-tools | 提供商工具/架构兼容助手 | ProviderToolCompatFamilybuildProviderToolCompatFamilyHooks,以及 DeepSeek/Gemini/OpenAI 架构清理 + 诊断 | | plugin-sdk/provider-usage | 提供商使用助手 | fetchClaudeUsagefetchGeminiUsagefetchGithubCopilotUsage 以及其他提供商使用助手 | | plugin-sdk/provider-stream | 提供商流包装助手 | ProviderStreamFamilybuildProviderStreamFamilyHookscomposeProviderStreamWrappers、流包装类型以及共享 Anthropic/Bedrock/DeepSeek V4/Google/Kilocode/Moonshot/OpenAI/OpenRouter/Z.A.I/MiniMax/Copilot 包装助手 | | plugin-sdk/provider-transport-runtime | 提供商传输助手 | 原生提供商传输助手,例如受保护获取、传输消息转换和可写传输事件流 | | plugin-sdk/keyed-async-queue | 有序异步队列 | KeyedAsyncQueue | | plugin-sdk/media-runtime | 共享媒体助手 | 媒体获取/转换/存储助手、基于 ffprobe 的视频尺寸探测以及媒体负载构建器 | | plugin-sdk/media-generation-runtime | 共享媒体生成助手 | 共享故障转移助手、候选选择以及图像/视频/音乐生成的缺失模型消息传递 | | plugin-sdk/media-understanding | 媒体理解助手 | 媒体理解提供商类型以及提供商导向的图像/音频助手导出 | | plugin-sdk/text-runtime | 已弃用的广泛文本兼容性导出 | 使用 string-coerce-runtimetext-chunkingtext-utility-runtimelogging-core | | plugin-sdk/text-chunking | 文本分块助手 | 出站文本分块助手 | | plugin-sdk/speech | 语音助手 | 语音提供商类型以及提供商导向的指令、注册、验证助手和 OpenAI 兼容 TTS 构建器 | | plugin-sdk/speech-core | 共享语音核心 | 语音提供商类型、注册、指令、规范化 | | plugin-sdk/realtime-transcription | 实时转录助手 | 提供商类型、注册助手和共享 WebSocket 会话助手 | | plugin-sdk/realtime-voice | 实时语音助手 | 提供商类型、注册/解析助手、桥接会话助手、共享代理回话队列、转录/事件运行状况、回声抑制和快速上下文咨询助手 | | plugin-sdk/image-generation | 图像生成助手 | 图像生成提供商类型、图像资源/数据 URL 助手以及 OpenAI 兼容图像提供商构建器 | | plugin-sdk/image-generation-core | 共享图像生成核心 | 图像生成类型、故障转移、身份验证和注册助手 | | plugin-sdk/music-generation | 音乐生成助手 | 音乐生成提供商/请求/结果类型 | | plugin-sdk/music-generation-core | 共享音乐生成核心 | 音乐生成类型、故障转移助手、提供商查找和模型引用解析 | | plugin-sdk/video-generation | 视频生成助手 | 视频生成提供商/请求/结果类型 | | plugin-sdk/video-generation-core | 共享视频生成核心 | 视频生成类型、故障转移助手、提供商查找和模型引用解析 | | plugin-sdk/interactive-runtime | 交互式回复助手 | 交互式回复负载规范化/简化 | | plugin-sdk/channel-config-primitives | 渠道配置原语 | 精简渠道配置架构原语 | | plugin-sdk/channel-config-writes | 渠道配置写入助手 | 渠道配置写入授权助手 | | plugin-sdk/channel-plugin-common | 共享渠道前奏 | 共享渠道插件前奏导出 | | plugin-sdk/channel-status | 渠道状态助手 | 共享渠道状态快照/摘要助手 | | plugin-sdk/allowlist-config-edit | 允许列表配置助手 | 允许列表配置编辑/读取助手 | | plugin-sdk/group-access | 群组访问助手 | 共享群组访问决策助手 | | plugin-sdk/direct-dm | 直接私信助手 | 共享直接私信身份验证/保护助手 | | plugin-sdk/extension-shared | 共享扩展助手 | 被动渠道/状态和环境代理助手原语 | | plugin-sdk/webhook-targets | Webhook 目标助手 | Webhook 目标注册和路由安装助手 | | plugin-sdk/webhook-path | 已弃用的 Webhook 路径别名 | 使用 plugin-sdk/webhook-ingress | | plugin-sdk/web-media | 共享网络媒体助手 | 远程/本地媒体加载助手 | | plugin-sdk/zod | 已弃用的 Zod 兼容性重新导出 | 直接从 zod 导入 zod | | plugin-sdk/memory-core | 捆绑内存核心助手 | 内存管理器/配置/文件/CLI 助手接口 | | plugin-sdk/memory-core-engine-runtime | 内存引擎运行时外观 | 内存索引/搜索运行时外观 | | plugin-sdk/memory-core-host-engine-foundation | 内存主机基础引擎 | 内存主机基础引擎导出 | | plugin-sdk/memory-core-host-engine-embeddings | 内存主机嵌入引擎 | 内存嵌入合约、注册访问、本地提供商以及通用批处理/远程助手;具体的远程提供商位于其所属插件中 | | plugin-sdk/memory-core-host-engine-qmd | 内存主机 QMD 引擎 | 内存主机 QMD 引擎导出 | | plugin-sdk/memory-core-host-engine-storage | 内存主机存储引擎 | 内存主机存储引擎导出 | | plugin-sdk/memory-core-host-multimodal | 内存主机多模态助手 | 内存主机多模态助手 | | plugin-sdk/memory-core-host-query | 内存主机查询助手 | 内存主机查询助手 | | plugin-sdk/memory-core-host-secret | 内存主机密钥助手 | 内存主机密钥助手 | | plugin-sdk/memory-core-host-events | 已弃用的内存事件别名 | 使用 plugin-sdk/memory-host-events | | plugin-sdk/memory-core-host-status | 内存主机状态助手 | 内存主机状态助手 | | plugin-sdk/memory-core-host-runtime-cli | 内存主机 CLI 运行时 | 内存主机 CLI 运行时助手 | | plugin-sdk/memory-core-host-runtime-core | 内存主机核心运行时 | 内存主机核心运行时助手 | | plugin-sdk/memory-core-host-runtime-files | 内存主机文件/运行时助手 | 内存主机文件/运行时助手 | | plugin-sdk/memory-host-core | 内存主机核心运行时别名 | 内存主机核心运行时助手的供应商中立别名 | | plugin-sdk/memory-host-events | 内存主机事件日志别名 | 内存主机事件日志助手的供应商中立别名 | | plugin-sdk/memory-host-files | 已弃用的内存文件/运行时别名 | 使用 plugin-sdk/memory-core-host-runtime-files | | plugin-sdk/memory-host-markdown | 托管 Markdown 助手 | 用于内存相邻插件的共享托管 Markdown 助手 | | plugin-sdk/memory-host-search | 活动内存搜索外观 | 延迟活动内存搜索管理器运行时外观 | | plugin-sdk/memory-host-status | 已弃用的内存主机状态别名 | 使用 plugin-sdk/memory-core-host-status | | plugin-sdk/testing | 测试工具 | 仓库本地已弃用的兼容性导出桶;使用专注的仓库本地测试子路径,例如 plugin-sdk/plugin-test-runtimeplugin-sdk/channel-test-helpersplugin-sdk/channel-target-testingplugin-sdk/test-envplugin-sdk/test-fixtures |

此表格特意列出通用的迁移子集,而非完整的 SDK 表面。编译器入口点清单位于 scripts/lib/plugin-sdk-entrypoints.json;包导出内容源自公共子集。

保留的捆绑插件辅助接口已从公共 SDK 导出映射中移除,明确记录的兼容性外观(如已弃用的 plugin-sdk/discord 垫片,为已发布的 @openclaw/[email protected] 包所保留)除外。特定于所有者的辅助工具位于其所属的插件包内部;共享的主机行为应通过通用 SDK 契约(如 plugin-sdk/gateway-runtimeplugin-sdk/security-runtimeplugin-sdk/plugin-config-runtime)进行流转。

使用与任务匹配的最窄导入。如果您找不到导出,请检查 src/plugin-sdk/ 处的源代码,或询问维护人员应由哪个通用契约拥有它。

适用于插件 SDK、提供商契约、 运行时界面和清单的更具体弃用项。每一项目前仍然有效,但将在 未来的主要版本中移除。每个项目下方的条目将旧的 API 映射到其 规范替代项。

command-auth help builders → command-status

旧版 (openclaw/plugin-sdk/command-auth)buildCommandsMessagebuildCommandsMessagePaginatedbuildHelpMessage

新版 (openclaw/plugin-sdk/command-status):相同的签名,相同的导出——只是从更窄的子路径导入。command-auth 将它们作为兼容存根重新导出。

// Before
import { buildHelpMessage } from "openclaw/plugin-sdk/command-auth";
// After
import { buildHelpMessage } from "openclaw/plugin-sdk/command-status";
Mention gating helpers → resolveInboundMentionDecision

旧版:来自 openclaw/plugin-sdk/channel-inboundopenclaw/plugin-sdk/channel-mention-gatingresolveInboundMentionRequirement({ facts, policy })shouldDropInboundForMention(...)

新版resolveInboundMentionDecision({ facts, policy })——返回单个决策对象,而不是两次分离的调用。

下游渠道插件(Slack、Discord、Matrix、MS Teams)已经完成切换。

Channel runtime shim and 渠道 actions helpers

openclaw/plugin-sdk/channel-runtime 是旧版 渠道插件的兼容性垫片。请勿在新代码中导入它;请使用 openclaw/plugin-sdk/channel-runtime-context 来注册运行时 对象。

channelActions* 辅助函数位于 openclaw/plugin-sdk/channel-actions 中,已与原始 “actions” 渠道导出一同弃用。请通过语义化的 presentation 接口来公开能力 - 渠道插件声明它们渲染的内容(卡片、按钮、选择器),而不是它们接受的原始操作名称。

Web search 提供商 工具() helper → createTool() on the plugin

旧版:来自 openclaw/plugin-sdk/provider-web-searchtool() 工厂。

新版:直接在提供商插件上实现 createTool(...)。 OpenClaw 不再需要 SDK 辅助函数来注册工具包装器。

Plaintext 渠道 envelopes → BodyForAgent

旧版:使用 formatInboundEnvelope(...)(和 ChannelMessageForAgent.channelEnvelope)从传入的渠道消息构建扁平的纯文本提示信封。

新版:使用 BodyForAgent 加上结构化的用户上下文块。渠道插件将路由元数据(主题串、话题、回复对象、回应)作为类型化字段附加,而不是将其连接到提示字符串中。formatAgentEnvelope(...) 辅助函数仍支持合成的面向助手的信封,但传入的纯文本信封即将被淘汰。

受影响的区域:inbound_claimmessage_received 以及任何对 channelEnvelope 文本进行后处理的自定义渠道插件。

deactivate hook → gateway_stop

旧版: api.on("deactivate", handler)

新版: api.on("gateway_stop", handler)。事件和上下文是相同的关闭清理约定;仅挂钩名称更改。

// Before
api.on("deactivate", async (event, ctx) => {
await stopPluginService(ctx);
});
// After
api.on("gateway_stop", async (event, ctx) => {
await stopPluginService(ctx);
});

deactivate 作为已弃用的兼容性别名一直保留到 2026-08-16 之后。

Provider discovery types → 提供商 catalog types

四个发现类型别名现在是目录时代类型的简单封装:

旧别名新类型
ProviderDiscoveryOrderProviderCatalogOrder
ProviderDiscoveryContextProviderCatalogContext
ProviderDiscoveryResultProviderCatalogResult
ProviderPluginDiscoveryProviderPluginCatalog

此外还有遗留的 ProviderCapabilities 静态包 —— 提供商插件应使用显式的提供商挂钩(如 buildReplayPolicynormalizeToolSchemaswrapStreamFn),而不是静态对象。

Thinking policy hooks → resolveThinkingProfile

旧版ProviderThinkingPolicy 上的三个独立挂钩): isBinaryThinking(ctx)supportsXHighThinking(ctx)resolveDefaultThinkingLevel(ctx)

新版:单个 resolveThinkingProfile(ctx),它返回一个 ProviderThinkingProfile,其中包含规范 id、可选 labelOpenClaw 和 排名的级别列表。OpenClaw 会根据配置文件排名自动降级过期的存储值。

实现一个挂钩而不是三个。旧版挂钩在弃用窗口期间继续工作,但不会与配置文件结果组合。

OAuthExternal OAuth 提供商回退 → contracts.externalAuthProviders

:在未于插件清单中声明提供商的情况下实现 resolveExternalOAuthProfiles(...)

:在插件清单中声明 contracts.externalAuthProviders 实现 resolveExternalAuthProfiles(...)。旧的“身份验证回退”路径会在运行时发出警告,并且将被移除。

{
"contracts": {
"externalAuthProviders": ["anthropic", "openai"]
}
}
Provider env-var lookup → setup.providers[].envVars

清单字段:providerAuthEnvVars: { anthropic: ["ANTHROPIC_API_KEY"] }

:将相同的环境变量查找映射到清单上的 setup.providers[].envVars 中。这可以将设置/状态环境元数据集中在一个位置,并避免仅为了回答环境变量查找而启动插件运行时。

providerAuthEnvVars 在弃用窗口关闭前仍通过兼容性适配器获得支持。

Memory plugin registration → registerMemoryCapability

:三个独立的调用 - api.registerMemoryPromptSection(...)api.registerMemoryFlushPlan(...)api.registerMemoryRuntime(...)API。

:在内存状态 API 上的一个调用 - registerMemoryCapability(pluginId, { promptBuilder, flushPlanResolver, runtime })

相同的插槽,单一的注册调用。附加内存辅助工具 (registerMemoryPromptSupplementregisterMemoryCorpusSupplementregisterMemoryEmbeddingProvider)不受影响。

Subagent 会话 messages types renamed

src/plugins/runtime/types.ts 中仍导出了两个旧版类型别名:

SubagentReadSessionParamsSubagentGetSessionMessagesParams
SubagentReadSessionResultSubagentGetSessionMessagesResult

运行时方法 readSession 已被弃用,取而代之的是 getSessionMessages。签名相同;旧方法会调用新方法。

runtime.tasks.flow → runtime.tasks.managedFlows

旧版: runtime.tasks.flow (单数形式) 返回一个实时的任务流访问器。

新版: runtime.tasks.managedFlows 保留了受管理的 TaskFlow 变异 运行时,用于从流中创建、更新、取消或运行子任务的插件。当插件仅需要基于 DTO 的读取时,请使用 runtime.tasks.flows

// Before
const flow = api.runtime.tasks.flow.fromToolContext(ctx);
// After
const flow = api.runtime.tasks.managedFlows.fromToolContext(ctx);
Embedded extension factories → agent 工具-result middleware

这在上面的“如何迁移 → 将 Pi 工具结果扩展迁移到中间件”中已涵盖。为了完整性在此列出:仅限 Pi 的已移除 api.registerEmbeddedExtensionFactory(...) 路径被 api.registerAgentToolResultMiddleware(...) 取代,并在 contracts.agentToolResultMiddleware 中具有显式的运行时列表。

OpenClawSchemaType alias → OpenClawConfig

openclaw/plugin-sdk 重新导出的 OpenClawSchemaType 现在是 OpenClawConfig 的单行别名。首选使用规范名称。

// Before
import type { OpenClawSchemaType } from "openclaw/plugin-sdk";
// After
import type { OpenClawConfig } from "openclaw/plugin-sdk/config-schema";

时间发生的情况
现在已弃用的接口会发出运行时警告
下一个主要版本已弃用的接口将被移除;仍在使用它们的插件将会失败

所有核心插件已迁移完毕。外部插件应在下一个主要版本发布前完成迁移。

在进行迁移工作时,请设置这些环境变量:

Terminal window
OPENCLAW_SUPPRESS_PLUGIN_SDK_COMPAT_WARNING=1 openclaw gateway run
OPENCLAW_SUPPRESS_EXTENSION_API_WARNING=1 openclaw gateway run

这是一个临时的应急方案,并非永久解决方案。