## 概要
为 Skill-first "应用与服务目录" 路线图新增两个元技能,作为 builtin 同步到用户
~/.desirecore/skills/:
- registering-services — 教 Agent 安全注册外部 HTTP/MCP 服务(riskLevel
选择、secretRef、SSRF、人类审批)
- using-services — 教 Agent 发现并调用目录服务(status/reviewStatus 过滤、HTTP/MCP
两条路径、不绕开治理)
## 改动
- skills/registering-services/{SKILL.md, SKILL.zh-CN.md}
- skills/using-services/{SKILL.md, SKILL.zh-CN.md}
- builtin-skills.json 加 2 个技能 id
- manifest.json totalSkills 22 → 24(已 rebase 到含 #18 tech-diagram 的 main)
- SKILL.zh-CN.md 采用 `<!-- locale: zh-CN -->` body 格式(移除冗余 frontmatter,对齐
docs/I18N.md 约定)
## 配套
主仓库 PR 同步引入:schema 扩展、新存储层、注册/治理路由、service-approval、http-request
治理闸门、per-service Skill 生成器、docker-app 派生 + service-health、前端徽章/治理
UI/派生服务面板。
## CLA
- [x] I have read and agree to the Contributor License Agreement
6.1 KiB
name, description, version, type, risk_level, status, disable-model-invocation, tags, metadata, market
| name | description | version | type | risk_level | status | disable-model-invocation | tags | metadata | market | |||||||||||||||||||||||||||||||||||||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| using-services | Discover and invoke HTTP/MCP services already registered in the global catalog. Use when the user asks the Agent to call an API, search for an existing service, or query a backend that was registered via the registering-services skill. 调用某个 API、查找已有服务、访问已注册的后端服务时使用。 | 1.0.0 | meta | low | enabled | true |
|
|
|
using-services Skill
L0: One-line Summary
Teach the Agent how to look up and call services from the global "Apps & Services" catalog.
L1: Overview
The "Apps & Services" catalog stores all registered HTTP/MCP services. This
meta-skill is your manual for finding the right service and invoking
it correctly. Each non-trivial registered service also has its own
svc-<id> Skill auto-generated from its operations — prefer that when it
exists; this meta-skill is the fallback for ad-hoc discovery.
When to use
- The user asks you to do something that might already have a registered service (e.g. "search the product database", "send a notification")
- You see
svc-<id>Skill in your available skills list — activate it directly - You need to call an HTTP API and want to check if it's been registered (to benefit from governance, credential injection, and audit)
When NOT to use
- The user gives you a one-off URL to fetch — use
HttpRequestdirectly - You already have the per-service
svc-<id>Skill activated — follow it instead, it's more specific
L2: How to discover and call
Step 1 — List the catalog
Fetch the registry:
tool: HttpRequest
parameters:
url: http://127.0.0.1:<agent-service-port>/api/registry/services
method: GET
Response shape (excerpt):
{
"data": {
"services": [
{
"id": "acme-search-api",
"name": "Acme Search API",
"protocol": "http",
"endpoint": "https://api.acme.example/search",
"tags": ["search", "products"],
"status": "online",
"origin": "agent",
"reviewStatus": "approved",
"riskLevel": "medium",
"operations": [...]
}
],
"total": 1,
"source": "official"
}
}
Step 2 — Pick a candidate
Filter by tags, protocol, name. Important checks before invoking:
status === 'online'→ safe to callstatus === 'offline'/'error'→ tell the user the service is down, don't retry blindlystatus === 'degraded'→ degrade gracefully, mention it to the userreviewStatus === 'pending'(onlyorigin='agent') → you can only call it ifregisteredByis you; otherwise ask the user to promote itriskLevel === 'critical'→ expect a human approval prompt on every call
Step 3 — Build the request (HTTP services)
If the service has operations, prefer them — they define stable contract
points. Build the URL as <endpoint><operation.path>.
tool: HttpRequest
parameters:
url: https://api.acme.example/search/v1/items?q=widget
method: GET
headers:
Authorization: "Bearer ${secrets/api-keys/acme}" # resolved at call time
If the service declares auth.secretRef, do not prompt the user for the
secret value during chat. The HttpRequest tool resolves it automatically.
Step 4 — Build the request (MCP services)
MCP services aren't called via HttpRequest — they are tools exposed through
the Agent's mcp_servers config:
- If you haven't added the MCP service to your Agent yet, POST to
http://127.0.0.1:<agent-service-port>/api/agents/<your-id>/mcp-serverswith{ serverId: '<service.id>', config: <connection> } - Next query, MCP discovery will auto-expose tools from the server
- Call the tools by their MCP-declared names directly
Step 5 — Handle the response
- 2xx → parse and use
- 4xx → likely a client error (bad params, missing auth); fix the request, then retry once; if it still fails, report to the user
- 5xx → server-side problem, report
statusof the service back so the user knows - Service-approval rejected → response will contain
"decision":"rejected"; do not retry, ask the user how to proceed
Step 6 — Don't fall through to raw URL fetching
If the catalog has a service for what you need, use it. Don't bypass
governance by calling an undeclared URL directly — HttpRequest will still
work, but you lose:
- Approval gating for high-risk operations
- Credential injection (you'd need to ask the user for keys yourself)
- Audit trail and
lastUsedtracking - Other Agents being able to reuse your call patterns
Failure modes
- Catalog read fails: just fall back to direct
HttpRequestand warn the user that governance is bypassed. - No matching service: ask the user if they want to register a new
one — activate
registering-servicesskill. status === 'offline': report the situation, suggest checking the underlying service, don't call anyway.