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(Markdown/MDXファイルを型安全なデータコレクションに変換するTypeScriptファーストのツール)の本番環境でテストされた設定を提供します。Zodバリデーションによる型安全性を実現し、ブログ、ドキュメントサイト、コンテンツ重視のVite + Reactアプリケーション構築時にご利用ください。Viteプラグインの設定、MDXコンパイルから、デプロイ最適化、スキーマバリデーションまで、すべてを網羅しています。
polymarket
メタこのスキルは、開発者がPolymarket予測市場プラットフォームを活用したアプリケーション構築を可能にします。API統合による取引や市場データの取得に加え、WebSocketを介したリアルタイムデータストリーミングにより、ライブ取引や市場活動を監視できます。取引戦略の実装や、ライブ市場更新を処理するツールの作成にご利用ください。
creating-opencode-plugins
メタこのスキルは、開発者がコマンド、ファイル、LSP操作など25種類以上のイベントタイプにフックするOpenCodeプラグインを作成することを支援します。JavaScript/TypeScriptモジュール向けに、プラグイン構造、イベントAPI仕様、および実装パターンを提供します。カスタムイベント駆動ロジックでOpenCode AIアシスタントのライフサイクルをインターセプト、監視、または拡張する必要がある場合にご利用ください。
sglang
メタSGLangは、高性能なLLMサービングフレームワークであり、RadixAttentionプレフィックスキャッシュを活用したJSON、正規表現、エージェントワークフロー向けの高速で構造化された生成を特長とします。特にプレフィックスが繰り返されるタスクにおいて、大幅に高速な推論を実現し、複雑な構造化出力やマルチターン対話に最適です。制約付きデコードが必要な場合や、広範なプレフィックス共有を伴うアプリケーションを構築する場合は、vLLMなどの代替案ではなくSGLangを選択してください。
