使用 Services API 向 Agent Registry 显式注册代理或 Model Context Protocol (MCP) 服务器时,您必须提供描述其功能的配置文件。
Agent Registry 会根据外部开源规范验证您上传的文件,然后再对其进行索引,以发现智能体技能和工具。
本文档提供了一些示例,并提供了一些链接,用于说明代理卡片和 MCP 工具规范的预期 JSON 结构。
智能体卡片架构
注册符合 A2A 标准的代理时,您的 agent-card.json 载荷必须遵循官方 A2A 规范。相应规范文件的大小上限为 10 KB。
skills 数组字段支持关键字搜索索引。
{
"name": "string",
"description": "string",
"version": "string",
"protocolVersion": "string",
"url": "string",
"skills": [
{
"id": "string",
"name": "string",
"description": "string",
"tags": [
"string"
],
"examples": [
"string"
]
}
],
"capabilities": {
"streaming": false,
"pushNotifications": false,
"stateTransitionHistory": false
},
"defaultInputModes": [
"text/plain"
],
"defaultOutputModes": [
"text/plain"
]
}
字段定义
name:代理的直观易懂的名称。description:对代理用途的高级总结。version:代理的版本,例如1.0.2。protocolVersion:代理实现的 Agent2Agent protocol 的版本,例如0.3.0。url:代理可访问的端点网址。capabilities:可选。一个对象,用于指定代理支持的操作功能,例如streaming、pushNotifications或stateTransitionHistory。defaultInputModes:可选。一个字符串数组,用于定义代理接受的默认 MIME 类型作为输入,例如["text/plain"]。defaultOutputModes:可选。一个字符串数组,用于定义代理作为输出生成的默认 MIME 类型,例如["text/plain"]。skills:代理所具备的功能的数组:id:技能的唯一程序化标识符。name:技能的直观易懂的名称。description:技能的详细说明。tags:用于对技能进行分类的关键字字符串数组。examples:此技能处理的提示或场景示例的数组。
MCP 工具架构
注册 MCP 服务器时,您的 toolspec.json 载荷必须包含符合 MCP Tool 对象架构的工具列表。
预期载荷是一个包含单个 tools 字段的 JSON 对象,与标准 MCP 工具或列表请求返回的载荷完全相同。相应规范文件的大小上限为 10 KB。
{
"tools": [
{
"name": "string",
"description": "string",
"inputSchema": {
"type": "object",
"properties": {}
},
"annotations": {
"title": "string",
"readOnlyHint": false,
"destructiveHint": true,
"idempotentHint": false,
"openWorldHint": true
}
}
]
}
字段定义
tools:服务器提供的一系列工具:name:工具的程序化标识符。description:直观易懂的工具用途说明。inputSchema:一个 JSON 架构对象,用于定义工具的预期参数。annotations:用于指导编排器代理如何与工具互动的行为提示:title:工具的人类可读标题。readOnlyHint:如果为true,则该工具仅检索数据,而不修改其环境。默认值为false。destructiveHint:如果为true,则该工具会执行可能会导致永久性更改的操作。默认值为true。idempotentHint:如果为true,则重复调用该工具不会产生额外效果。默认值为false。openWorldHint:如果为true,则工具会与外部系统互动。默认值为true。