AgentCard

AgentCard相当于Agent(智能体)的"名片",用于描述Agent的能力和技能,由开发者在Agent的配置文件agent_config.json中配置。

一个Agent就是一个AgentExtensionAbility实例。开发者可以通过AgentExtensionContext中的agentCard属性获取到当前AgentExtensionAbility的AgentCard。

说明:

本模块首批接口从API version 24 开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

导入模块

import { common } from '@kit.AbilityKit';

AgentCard

描述Agent的基本信息和能力。

模型约束: 此接口仅可在Stage模型下使用。

原子化服务API: 从API version 24开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.Ability.AgentRuntime.Core

名称 类型 只读 可选 说明
agentId string Agent的唯一标识符,在同一个应用下面agentId不可重复。
name string Agent的名称。使用方一般用于在UI界面中展示给用户,例如"Recipe Assistant"(食谱助手)。
description string Agent功能的描述。该描述应清晰说明Agent的核心功能和用途,帮助用户理解Agent能做什么,例如"帮助用户搜索食谱、规划菜单并提供烹饪建议"。
type agentConstant.AgentCardType AgentCard的类型。当agentConstant.AgentCardType的枚举值为LOW_CODE时,对应的应用必须是系统应用,否则Agent卡片无法注册、安装或更新。如果未指定,默认为APP类型。
起始版本: 26.0.0
原子化服务API: 从API版本26.0.0开始,该接口支持在原子化服务中使用。
provider AgentProvider Agent的服务提供商信息,包含提供商的组织名称和官方网站URL,用于标识Agent的来源和版权信息。
version string Agent的版本号。遵循语义化版本规范(如"1.0.0"),格式由提供商定义。版本号用于标识Agent的功能迭代和兼容性变化。
documentationUrl string Agent文档的URL。提供详细的Agent使用文档、API说明、示例和最佳实践指南,帮助开发者更好地集成和使用该Agent。
capabilities AgentCapabilities Agent支持的可选能力集合。定义Agent支持的其他可选能力,如流式响应、推送通知、状态历史查询等。
defaultInputModes Array<string> Agent在所有AgentSkill上支持的输入模式集。使用MIME类型格式定义支持的输入媒体类型,例如["text/plain"]表示纯文本输入,["application/json"]表示JSON结构化数据输入,["image/png"]表示图片输入。AgentSkill级别的inputModes会覆盖此默认设置。
defaultOutputModes Array<string> Agent在所有AgentSkill上支持的输出模式集。使用MIME类型格式定义支持的输出媒体类型,例如["text/plain"]表示纯文本输出,["application/html"]表示HTML格式输出,["application/json"]表示JSON数据输出。AgentSkill级别的outputModes会覆盖此默认设置。
skills Array<AgentSkill> Agent提供的功能集合。描述Agent可以执行的特定功能或技能,每个技能定义了具体的用途、标签和使用示例。Agent必须至少包含一个技能。
iconUrl string Agent图标的URL。提供Agent的可视化标识图标,用于在UI界面中展示,增强Agent的辨识度和用户体验。
category string Agent的类别。用于对Agent进行分类管理,常见的类别包括:"productivity"(生产力)、"entertainment"(娱乐)、"education"(教育)、"finance"(金融)、"health"(健康)等。
extension string Agent的扩展配置项。用于存储自定义的扩展配置信息,如Agent开场白、版本协议号等,格式为JSON字符串。
appInfo AgentAppInfo Agent所在的应用信息。包含Agent所属的应用包名、模块名和能力名等标识信息,用于定位和管理AgentExtensionAbility实例。

AgentProvider

表示Agent的服务提供商。

模型约束: 此接口仅可在Stage模型下使用。

原子化服务API: 从API version 24开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.Ability.AgentRuntime.Core

名称 类型 只读 可选 说明
organization string Agent提供商的组织名称。标识开发或提供该Agent的公司、组织或个人名称。
url string Agent提供商的网站或相关文档的URL。提供指向提供商官方网站、产品页面或相关文档的HTTPS链接,用于用户了解更多信息或获取支持。

AgentCapabilities

定义Agent支持的可选能力。

模型约束: 此接口仅可在Stage模型下使用。

原子化服务API: 从API version 24开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.Ability.AgentRuntime.Core

名称 类型 只读 可选 说明
streaming boolean Agent是否支持流式响应。
true:表示支持SSE(Server-Sent Events)流式响应,可以实时返回部分结果。
false:表示不支持流式,仅支持一次性返回完整结果。启用流式响应后,客户端可使用stream方法获取实时数据流。
pushNotifications boolean Agent是否支持为异步任务更新发送推送通知。
true:表示支持,当长时间运行的任务状态发生变化时(如任务完成、失败或进度更新),Agent可以主动推送通知给客户端。
false:表示不支持,客户端需要轮询查询任务状态。
stateTransitionHistory boolean Agent是否支持查看任务状态变化历史。
true:表示支持,客户端可以查询任务从创建到完成的完整状态转换记录(如pending->running->completed)。
false:表示不支持状态历史查询。
extendedAgentCard boolean Agent是否支持在认证时提供扩展的AgentCard。
true:表示支持,客户端在通过认证后可以获取包含额外信息(如私有配置、高级能力)的扩展AgentCard。
false:表示仅提供基础AgentCard。
extension string Agent支持的协议扩展。用于存储自定义的扩展能力配置,格式为JSON字符串,可以包含协议级别的扩展参数和自定义字段,由开发者和Agent使用方约定。

AgentSkill

表示Agent可以执行的不同能力或功能。

模型约束: 此接口仅可在Stage模型下使用。

原子化服务API: 从API version 24开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.Ability.AgentRuntime.Core

名称 类型 只读 可选 说明
id string AgentSkill的唯一标识符,在一个AgentCard中必须唯一。建议使用具有语义的命名格式(如"route-planner"、"recipe-search"),用于在API调用中精确指定要使用的技能。
name string AgentSkill的名称。用于在UI界面中展示,例如"Route Planning"(路线规划)或"Recipe Search"(食谱搜索)。
description string AgentSkill的详细描述。应清晰说明该技能的具体功能、适用场景和能解决的问题,例如"帮助用户规划两点之间的出行路线,提供多种交通方式选择和实时路况信息"。
tags Array<string> 描述AgentSkill能力的关键字标签。用于技能分类、检索和推荐,例如["maps", "routing", "navigation"]或["cooking", "recipe", "food"]。标签应简洁明了,便于用户理解和搜索。
examples Array<string> AgentSkill可以处理的示例提示或使用场景。提供具体的示例可以帮助用户理解如何使用该技能,例如["规划从上海到北京的路线"]。
inputModes Array<string> AgentSkill支持的输入模式。使用MIME类型格式定义,例如["text/plain"]。如果未设置,将使用AgentCard级别的defaultInputModes。该字段允许为特定技能自定义输入类型,覆盖默认设置。
outputModes Array<string> AgentSkill支持的输出模式。使用MIME类型格式定义,例如["text/plain", "application/html", "video/mp4"]。如果未设置,将使用AgentCard级别的defaultOutputModes。该字段允许为特定技能自定义输出类型,覆盖默认设置。
extension string AgentSkill的扩展配置项。用于存储技能级别的自定义扩展配置,格式为JSON字符串,可以包含技能特有的参数和配置信息。

AgentAppInfo

Agent的应用信息。

模型约束: 此接口仅可在Stage模型下使用。

原子化服务API: 从API version 24开始,该接口支持在原子化服务中使用。

系统能力: SystemCapability.Ability.AgentRuntime.Core

名称 类型 只读 可选 说明
bundleName string Agent所属AgentExtensionAbility的Bundle名称。
moduleName string Agent所属AgentExtensionAbility的Module名称。
abilityName string Agent所属AgentExtensionAbility的Ability名称。
deviceTypes Array<string> Agent支持的设备类型列表。取值范围参考deviceTypes
minAppVersion string Agent运行的最低应用版本要求。使用语义化版本号格式(如"1.0.0"),指定运行该Agent所需的应用最低版本。低于此版本的应用将无法正确加载和运行该Agent。