design-a2a-agent-card
О программе
Этот навык генерирует манифест карты агента A2A (agent.json), который определяет возможности агента, аутентификацию и поддерживаемые типы контента для обеспечения взаимодействия. Используйте его при создании или миграции агентов, которые должны быть обнаруживаемыми другими агентами, совместимыми со стандартом A2A, или интегрироваться с реестрами агентов. Он помогает установить публичный контракт для оркестрации мультиагентных систем.
Быстрая установка
Claude Code
Рекомендуетсяnpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/design-a2a-agent-cardСкопируйте и вставьте эту команду в Claude Code для установки этого навыка
Документация
Design A2A Agent Card
Make A2A Agent Card. Advertises agent identity, skills, auth, capabilities. Other agents find it.
When Use
- Build agent others must discover via A2A
- Expose agent capabilities for multi-agent orchestration
- Migrate existing agent to A2A (Agent-to-Agent) protocol
- Define public contract before implementation
- Integrate with agent registries that read Agent Cards
Inputs
- Required: Agent name + description
- Required: Skill list (name, description, input/output schemas)
- Required: Base URL where agent hosted
- Optional: Auth method (
none,oauth2,oidc,api-key) - Optional: Content types beyond
text/plain(e.g.,image/png,application/json) - Optional: Capability flags (streaming, push notifications, state history)
- Optional: Provider org name + URL
Steps
Step 1: Set Agent Identity + Description
1.1. Pick identity fields:
{
"name": "data-analysis-agent",
"description": "Performs statistical analysis, data visualization, and report generation on tabular datasets.",
"url": "https://agent.example.com",
"provider": {
"organization": "Example Corp",
"url": "https://example.com"
},
"version": "1.0.0"
}
1.2. Write clear, actionable description. Answer:
- What domains agent covers?
- What tasks handles?
- What limits?
1.3. Set canonical URL where Agent Card served at /.well-known/agent.json.
Got: Full identity block: name, description, URL, provider, version.
If fail: Agent covers many domains? Decide: one agent, many skills? Or many agents, focused scope? A2A prefers focused agents, clear boundaries.
Step 2: List Skills with I/O Schemas
2.1. Define each skill:
{
"skills": [
{
"id": "analyze-dataset",
"name": "Analyze Dataset",
"description": "Run descriptive statistics, correlation analysis, or hypothesis tests on a CSV dataset.",
"tags": ["statistics", "data-analysis", "csv"],
"examples": [
"Analyze the correlation between columns A and B in my dataset",
"Run a t-test comparing group 1 and group 2"
],
"inputModes": ["text/plain", "application/json"],
"outputModes": ["text/plain", "application/json", "image/png"]
},
{
"id": "generate-chart",
"name": "Generate Chart",
"description": "Create bar, line, scatter, or histogram charts from tabular data.",
"tags": ["visualization", "charts"],
"examples": [
"Create a scatter plot of height vs weight",
"Generate a histogram of the age column"
],
"inputModes": ["text/plain", "application/json"],
"outputModes": ["image/png", "image/svg+xml"]
}
]
}
2.2. Each skill needs:
- id: Unique ID (kebab-case)
- name: Human-readable name
- description: What skill does, 1-2 sentences
- tags: Keywords for discovery
- examples: Natural-language task examples that trigger skill
- inputModes: MIME types skill takes
- outputModes: MIME types skill produces
2.3. Skill boundaries must be clear, no overlap. Each task → one skill.
Got: Skills array. Each entry: id, name, description, tags, examples, I/O modes.
If fail: Skills overlap big? Merge into broader skill with more examples. Skill too broad? Split into focused sub-skills.
Step 3: Config Auth
3.1. Pick auth scheme by deploy context:
No auth (local/trusted network):
{
"authentication": {
"schemes": []
}
}
OAuth 2.0 (best for prod):
{
"authentication": {
"schemes": ["oauth2"],
"credentials": {
"oauth2": {
"authorizationUrl": "https://auth.example.com/authorize",
"tokenUrl": "https://auth.example.com/token",
"scopes": {
"agent:invoke": "Invoke agent skills",
"agent:read": "Read task status"
}
}
}
}
}
API Key (simple shared secret):
{
"authentication": {
"schemes": ["apiKey"],
"credentials": {
"apiKey": {
"headerName": "X-API-Key"
}
}
}
}
3.2. Pick minimum viable auth for env:
- Local dev:
none - Internal service:
apiKey - Public-facing:
oauth2oroidc
3.3. Document token/key provisioning in provider section or external docs.
Got: Auth block matches deploy security needs.
If fail: No OAuth 2.0 infra? Start with API key, plan migration. Never deploy public agent with none auth.
Step 4: Declare Capabilities
4.1. Declare protocol features agent supports:
{
"capabilities": {
"streaming": true,
"pushNotifications": false,
"stateTransitionHistory": true
}
}
4.2. Set each flag by impl readiness:
- streaming:
trueif agent supports SSE streaming viatasks/sendSubscribe. Real-time progress for long tasks. - pushNotifications:
trueif agent can send webhook callbacks on state change. Agent stores + calls webhook URLs. - stateTransitionHistory:
trueif agent keeps full state transition history (submitted, working, completed). Good for audit.
4.3. Only set true if impl fully supports. Fake flags break interop.
Got: Capabilities object. Flags match real impl.
If fail: Unsure if capability coming? Set false. Add later. Removing capability = breaking change.
Step 5: Validate + Publish Agent Card
5.1. Assemble full card:
{
"name": "data-analysis-agent",
"description": "Performs statistical analysis and visualization on tabular datasets.",
"url": "https://agent.example.com",
"version": "1.0.0",
"provider": {
"organization": "Example Corp",
"url": "https://example.com"
},
"authentication": {
"schemes": ["oauth2"],
"credentials": { ... }
},
"capabilities": {
"streaming": true,
"pushNotifications": false,
"stateTransitionHistory": true
},
"skills": [ ... ],
"defaultInputModes": ["text/plain"],
"defaultOutputModes": ["text/plain"]
}
5.2. Validate:
- Parse as JSON, check no syntax err
- All required fields present (name, description, url, skills)
- Each skill has id, name, description, min 1 I/O mode
- URL reachable, serves card at
/.well-known/agent.json
5.3. Publish:
- Serve at
https://<agent-url>/.well-known/agent.json - Set
Content-Type: application/json - Enable CORS if cross-origin discovery needed
- Register with relevant agent registries
5.4. Test by fetching:
curl -s https://agent.example.com/.well-known/agent.json | python3 -m json.tool
Got: Valid JSON Agent Card at well-known URL. Any A2A client can parse.
If fail: JSON invalid? Use linter to find syntax err. URL unreachable? Check DNS, SSL cert, web server config. CORS needed? Add Access-Control-Allow-Origin headers.
Checks
- Agent Card valid JSON, no syntax err
- Required fields present: name, description, url, skills
- Each skill has id, name, description, inputModes, outputModes
- Auth scheme matches deploy security
- Capability flags match impl
- Served at
/.well-known/agent.json, right Content-Type - A2A clients fetch + parse OK
- Examples realistic, trigger right skill
Pitfalls
- Overpromising capabilities:
streaming: trueorpushNotifications: truewithout impl = client fails when used. Be conservative. - Vague skill description: "does data stuff" blocks accurate matching. Be specific about inputs, outputs, domains.
- Missing CORS headers: Browser A2A clients can't fetch Agent Card without CORS.
- Skill overlap: Two skills handle same task → client can't pick. Keep boundaries clear.
- Forgetting default modes: No
defaultInputModes/defaultOutputModes→ clients unsure what content types to send. - Version stagnation: Bump version when skills/capabilities change. Clients cache old versions.
- Publish before impl: Agent Card = contract. Publishing unimplemented skills → runtime failure.
See Also
implement-a2a-server- impl server behind Agent Cardtest-a2a-interop- validate Agent Card conformance + interopbuild-custom-mcp-server- MCP as alt/complement to A2Aconfigure-mcp-server- MCP config patterns for A2A setup
GitHub репозиторий
Похожие навыки
content-collections
МетаЭтот навык предоставляет проверенную в продакшене настройку для Content Collections — TypeScript-ориентированного инструмента, который преобразует файлы Markdown/MDX в типобезопасные коллекции данных с валидацией Zod. Используйте его при создании блогов, сайтов документации или контентных приложений на Vite + React для обеспечения типобезопасности и автоматической проверки содержимого. Он охватывает всё: от настройки плагина Vite и компиляции MDX до оптимизации развертывания и валидации схем.
polymarket
МетаЭтот навык позволяет разработчикам создавать приложения на платформе прогнозных рынков Polymarket, включая интеграцию с API для торговли и получения рыночных данных. Он также обеспечивает потоковую передачу данных в реальном времени через WebSocket для отслеживания текущих сделок и рыночной активности. Используйте его для реализации торговых стратегий или создания инструментов, обрабатывающих обновления рынка в реальном времени.
creating-opencode-plugins
МетаЭтот навык помогает разработчикам создавать плагины OpenCode, которые подключаются к более чем 25 типам событий, таким как команды, файлы и операции LSP. Он предоставляет структуру плагина, спецификации API событий и шаблоны реализации для модулей на JavaScript/TypeScript. Используйте его, когда вам нужно перехватывать, отслеживать или расширять жизненный цикл ассистента OpenCode AI с помощью пользовательской событийно-ориентированной логики.
sglang
МетаSGLang — это высокопроизводительный фреймворк для обслуживания больших языковых моделей (LLM), специализирующийся на быстрой структурированной генерации JSON, regex и рабочих процессов агентов с использованием кэширования префиксов RadixAttention. Он обеспечивает значительно более высокую скорость вывода, особенно для задач с повторяющимися префиксами, что делает его идеальным для сложных структурированных результатов и многократных диалогов. Выбирайте SGLang вместо альтернатив, таких как vLLM, когда вам требуется ограниченное декодирование или вы создаете приложения с интенсивным совместным использованием префиксов.
