MCP HubMCP Hub
스킬 목록으로 돌아가기

design-a2a-agent-card

pjt222
업데이트됨 Yesterday
4 조회
17
2
17
GitHub에서 보기
메타design

정보

이 스킬은 상호 운용성을 위해 에이전트의 기능, 인증 요구 사항 및 지원 콘텐츠 유형을 정의하는 A2A 에이전트 카드 매니페스트(agent.json)를 생성합니다. A2A 프로토콜로 에이전트를 구축하거나 마이그레이션할 때 사용하여 다른 에이전트 및 레지스트리에서 검색 가능하도록 보장합니다. 다중 에이전트 오케스트레이션과 통합을 위한 공개 계약을 수립하는 데 도움이 됩니다.

빠른 설치

Claude Code

추천
기본
npx skills add pjt222/agent-almanac -a claude-code
플러그인 명령대체
/plugin add https://github.com/pjt222/agent-almanac
Git 클론대체
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/design-a2a-agent-card

Claude Code에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요

문서

Design A2A Agent Card

建合標之 A2A Agent Card,以告代理之身分、技能、認證需求與能力,供他代理發現。

適用時機

  • 建代理,須為他 A2A 相容代理所發現
  • 為多代理編排暴露代理能力
  • 將既有代理遷至 A2A(Agent-to-Agent)協定
  • 實作前為代理定公開契約
  • 整合代理註冊表或消費 Agent Card 之目錄

輸入

  • 必需:代理之名與述
  • 必需:代理可行之技能清單(名、述、輸入/輸出 schema)
  • 必需:代理託管之基礎 URL
  • 可選:認證方法(noneoauth2oidcapi-key
  • 可選:超 text/plain 之受支援內容類型(如 image/pngapplication/json
  • 可選:能力旗標(串流、推播通知、狀態轉移歷史)
  • 可選:提供者組織名與 URL

步驟

步驟一:定代理身分與述

1.1. 擇代理身分欄位:

{
  "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. 書清晰、可執行之述,答:

  • 此代理涵何等領域?
  • 可處理何等任務?
  • 其限何?

1.3. 設代理卡將供應於 /.well-known/agent.json 之標準 URL。

預期: 完整之身分區塊,含名、述、URL、提供者、版本。

失敗時: 若代理服多領域,慮其宜為一代理具多技能,抑或多代理具聚焦範圍。A2A 偏好聚焦代理具明界。

步驟二:列技能之輸入/輸出 schema

2.1. 定代理可行之每一技能:

{
  "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. 為每技能提供:

  • id:唯一標識(kebab-case)
  • name:人類可讀之顯示名
  • description:一至二句述技能所行
  • tags:供發現之可搜尋關鍵字
  • examples:觸發此技能之自然語言任務例
  • inputModes:技能接受之 MIME 類型
  • outputModes:技能可生之 MIME 類型

2.3. 確保技能邊界明確且不重疊。每任務應精確對映至一技能。

預期: 技能陣列,每條目具 id、name、description、tags、examples、I/O 模式。

失敗時: 若技能重疊顯著,合之為單一較廣技能具更多例。若技能過廣,分之為聚焦之子技能。

步驟三:配認證

3.1. 依部署情境定認證方案:

無認證(本地/可信網路):

{
  "authentication": {
    "schemes": []
  }
}

OAuth 2.0(生產建議):

{
  "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(簡易共享密鑰):

{
  "authentication": {
    "schemes": ["apiKey"],
    "credentials": {
      "apiKey": {
        "headerName": "X-API-Key"
      }
    }
  }
}

3.2. 為部署環境擇最小可行之認證:

  • 本地開發:none
  • 內部服務:apiKey
  • 面向公開之代理:oauth2oidc

3.3. 於 Agent Card 之 provider 區或外部文檔載令牌/金鑰供應過程。

預期: 認證區塊合部署安全需求。

失敗時: 若 OAuth 2.0 基礎架構不可用,始以 API key 認證並計劃遷移。勿以 none 認證部署公開代理。

步驟四:載明能力

4.1. 宣告代理支援何等協定功能:

{
  "capabilities": {
    "streaming": true,
    "pushNotifications": false,
    "stateTransitionHistory": true
  }
}

4.2. 依實作就緒度設每能力旗標:

  • streaming:若代理透過 tasks/sendSubscribe 支援 SSE 串流則 true。為長任務啟用即時進度更新。
  • pushNotifications:若代理可於任務狀態變時發 webhook 回調則 true。需代理存並回調 webhook URL。
  • stateTransitionHistory:若代理維持任務狀態轉移之完整歷史(submitted、working、completed 等)則 true。有益於稽核軌跡。

4.3. 僅於實作全然支援時設能力為 true。廣告不支援之能力破壞互通。

預期: 能力物件具布林旗標合實際實作。

失敗時: 若不確能力將實作,設之為 false。能力可於未來版本加。移除能力為破壞性變。

步驟五:驗證並發布 Agent Card

5.1. 組裝完整 Agent 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. 驗 Agent Card:

  • 以 JSON 解析並驗無語法錯
  • 驗所有必需欄位存(name、description、url、skills)
  • 驗每技能有 id、name、description 及至少一輸入/輸出模式
  • 驗 URL 可達且於 /.well-known/agent.json 供應該卡

5.3. 發布 Agent Card:

  • https://<agent-url>/.well-known/agent.json 供應
  • Content-Type: application/json
  • 若需跨源發現則啟 CORS 標頭
  • 向任何相關代理目錄或註冊表註冊

5.4. 以取卡試發現:

curl -s https://agent.example.com/.well-known/agent.json | python3 -m json.tool

預期: 於 well-known URL 供應之有效 JSON Agent Card,任何 A2A 客戶端皆可解析。

失敗時: 若 JSON 驗證失敗,用 JSON 檢查器識語法錯。若 URL 不可達,查 DNS、SSL 憑證與 web 伺服器配置。若需 CORS,加 Access-Control-Allow-Origin 標頭。

驗證

  • Agent Card 為有效 JSON 且無語法錯
  • 所有必需欄位存:name、description、url、skills
  • 每技能有 id、name、description、inputModes、outputModes
  • 認證方案合部署安全需求
  • 能力旗標準確反映實作狀態
  • Agent Card 於 /.well-known/agent.json 以正確 Content-Type 供應
  • A2A 客戶端可成功取並解析該卡
  • 技能中之例真實且觸發正確之技能

常見陷阱

  • 過諾能力:未實作而設 streaming: truepushNotifications: true 致用該等功能時客戶端失敗。宜保守。
  • 技能述模糊:如「做資料之事」之述阻準確技能匹配。應於輸入、輸出與領域具體。
  • 缺 CORS 標頭:瀏覽器基之 A2A 客戶端若無適當 CORS 配置則無法取 Agent Card。
  • 技能重疊:若兩技能可處理同任務,客戶端代理無法判擇何者。宜確保明界。
  • 忘預設模式:若省 defaultInputModesdefaultOutputModes,客戶端可能不知送何等內容類型。
  • 版本停滯:技能或能力變時更 Agent Card 版本。客戶端可能快取舊版。
  • 實作前發布:Agent Card 為契約。發布尚未實作之技能致運行時失敗。

相關技能

  • implement-a2a-server - 實作 Agent Card 背後之伺服器
  • test-a2a-interop - 驗證 Agent Card 合規與互通
  • build-custom-mcp-server - MCP 伺服器作 A2A 之替/補
  • configure-mcp-server - MCP 配置模式,適用於 A2A 設定

GitHub 저장소

pjt222/agent-almanac
경로: i18n/wenyan-lite/skills/design-a2a-agent-card
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

연관 스킬

content-collections

메타

이 스킬은 콘텐츠 콜렉션(Content Collections)을 위한 프로덕션 검증된 설정을 제공합니다. 콘텐츠 콜렉션은 Markdown/MDX 파일을 Zod 검증이 포함된 타입 안전한 데이터 콜렉션으로 변환해주는 TypeScript 최우선 도구입니다. 블로그, 문서 사이트 또는 콘텐츠 중심의 Vite + React 애플리케이션을 구축할 때 타입 안전성과 자동 콘텐츠 검증을 보장하기 위해 사용하세요. Vite 플러그인 구성과 MDX 컴파일부터 배포 최적화 및 스키마 검증에 이르기까지 모든 것을 다룹니다.

스킬 보기

polymarket

메타

이 스킬은 개발자들이 Polymarket 예측 시장 플랫폼을 활용한 애플리케이션을 구축할 수 있도록 지원하며, 거래 및 시장 데이터를 위한 API 통합 기능을 포함합니다. 또한 WebSocket을 통한 실시간 데이터 스트리밍을 제공하여 실시간 거래와 시장 활동을 모니터링할 수 있습니다. 이를 통해 거래 전략을 구현하거나 실시간 시장 업데이트를 처리하는 도구를 생성하는 데 활용할 수 있습니다.

스킬 보기

creating-opencode-plugins

메타

이 스킬은 개발자들이 명령어, 파일, LSP 작업 등 25개 이상의 이벤트 유형에 연결되는 OpenCode 플러그인을 만들 수 있도록 돕습니다. JavaScript/TypeScript 모듈을 위한 플러그인 구조, 이벤트 API 명세, 구현 패턴을 제공합니다. OpenCode AI 어시스턴트의 라이프사이클을 사용자 정의 이벤트 기반 로직으로 가로채거나, 모니터링하거나, 확장해야 할 때 사용하세요.

스킬 보기

sglang

메타

SGLang은 RadixAttention 프리픽스 캐싱을 활용하여 JSON, 정규식, 에이전트 워크플로우를 위한 고속 구조화 생성에 특화된 고성능 LLM 서빙 프레임워크입니다. 특히 반복되는 프리픽스가 있는 작업에서 상당히 빠른 추론 속도를 제공하여 복잡한 구조화 출력 및 다중 턴 대화에 이상적입니다. 제약 디코딩이 필요하거나 광범위한 프리픽스 공유가 있는 애플리케이션을 구축할 때는 vLLM과 같은 대안보다 SGLang을 선택하십시오.

스킬 보기