当 OpenClaw 需要新的共享领域时使用本指南,例如图像生成、视频生成,或未来某个由供应商支持的功能领域。 规则:Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
- 插件 = 所有权边界
- 能力 = 共享核心契约
何时创建能力
当所有以下条件都成立时,创建新的能力:- 可能有多个供应商实现它。
- 渠道、工具或功能插件应能使用它,而无需关心供应商。
- 核心需要拥有回退、策略、配置或交付行为。
标准顺序
- 定义带类型的核心契约。
- 为该契约添加插件注册。
- 添加共享运行时辅助函数。
- 接入一个真实供应商插件作为证明。
- 将功能/渠道消费者迁移到运行时辅助函数。
- 添加契约测试。
- 记录面向操作者的配置和所有权模型。
内容归属
核心:- 请求/响应类型。
- 提供商注册表 + 解析。
- 回退行为。
- 配置 schema,并在嵌套对象、通配符、数组项和组合节点上传播
title/description文档元数据。 - 运行时辅助函数表面。
- 供应商 API 调用。
- 供应商凭证处理。
- 供应商特定的请求归一化。
- 注册能力实现。
- 调用
api.runtime.*或匹配的plugin-sdk/*-runtime辅助函数。 - 绝不直接调用供应商实现。
提供商与 harness 接缝
当行为属于模型提供商契约,而不是通用 Agent loop 时,使用提供商钩子。示例包括传输选择后的提供商特定请求参数、凭证配置偏好、提示词叠加层,以及模型/配置档故障转移后的跟进回退路由。 当行为属于正在执行一个回合的运行时时,使用智能体 harness 钩子。Harness 可以对成功但不可用的尝试结果进行分类,例如空响应、仅推理响应或仅规划响应,以便外层模型回退策略可以决定是否重试。 保持这两个接缝狭窄:- 核心拥有重试/回退策略。
- 提供商插件拥有提供商特定的请求/凭证/路由提示。
- Harness 插件拥有运行时特定的尝试分类。
- 第三方插件返回提示,而不是直接改变核心状态。
文件清单
对于新的能力,通常需要触及这些区域:src/<capability>/types.tssrc/<capability>/...registry/runtime.tssrc/plugins/types.tssrc/plugins/registry.tssrc/plugins/captured-registration.tssrc/plugins/contracts/registry.tssrc/plugins/runtime/types-core.tssrc/plugins/runtime/index.tssrc/plugin-sdk/<capability>.tssrc/plugin-sdk/<capability>-runtime.ts- 一个或多个内置插件包。
- 配置、文档、测试。
示例:图像生成
图像生成遵循标准形态:- 核心定义
ImageGenerationProvider。 - 核心暴露
registerImageGenerationProvider(...)。 - 核心暴露
runtime.imageGeneration.generate(...)。 openai、google、fal和minimax插件注册由供应商支持的实现。- 未来供应商注册同一契约,无需更改渠道/工具。
agents.defaults.imageModel分析图像。agents.defaults.imageGenerationModel生成图像。
审查清单
发布新能力前,请验证:- 没有渠道/工具直接导入供应商代码。
- 运行时辅助函数是共享路径。
- 至少有一个契约测试断言内置所有权。
- 配置文档命名了新的模型/配置键。
- 插件文档解释了所有权边界。