copilot-sdk▌
doggy8088/agent-skills · updated Apr 8, 2026
The GitHub Copilot SDK is a multi-platform agent runtime that embeds Copilot's agentic workflows into applications. It exposes the same engine behind Copilot CLI, enabling programmatic invocation without requiring custom orchestration development.
GitHub Copilot SDK
Overview
The GitHub Copilot SDK is a multi-platform agent runtime that embeds Copilot's agentic workflows into applications. It exposes the same engine behind Copilot CLI, enabling programmatic invocation without requiring custom orchestration development.
Status: Technical Preview (suitable for development and testing)
Supported Languages: TypeScript/Node.js, Python, Go, .NET
Primary Documentation
Language-Specific SDK Docs
CLI and Configuration Docs
- About GitHub Copilot CLI
- Using GitHub Copilot CLI
- Creating Custom Agents
- Custom Agents Configuration Reference
- Enhancing Agent Mode with MCP
- Supported AI Models
Prerequisites
- GitHub Copilot Subscription - Pro, Pro+, Business, or Enterprise
- GitHub Copilot CLI - Installed and authenticated (
copilot --version) - Runtime: Node.js 18+, Python 3.8+, Go 1.21+, or .NET 8.0+
Installation
| Language | Command |
|---|---|
| TypeScript/Node.js | npm install @github/copilot-sdk |
| Python | pip install github-copilot-sdk |
| Go | go get github.com/github/copilot-sdk/go |
| .NET | dotnet add package GitHub.Copilot.SDK |
Architecture
Application → SDK Client → JSON-RPC → Copilot CLI (server mode)
The SDK manages CLI lifecycle automatically. External server connections supported via cliUrl / cli_url.
Quick Start (TypeScript)
import { CopilotClient } from "@github/copilot-sdk";
const client = new CopilotClient();
await client.start();
const session = await client.createSession({ model: "gpt-5" });
// Register handler BEFORE send()
session.on((event) => {
if (event.type === "assistant.message") {
console.log(event.data.content);
}
});
await session.send({ prompt: "What is 2 + 2?" });
await session.destroy();
await client.stop();
Critical: Register event handlers before calling send() to capture all events.
For complete examples in all languages, see references/working-examples.md.
Core Concepts
Client
Main entry point. Manages CLI server lifecycle and session creation.
Operations: start(), stop(), createSession(), resumeSession()
Config: cliPath, cliUrl, port, useStdio, autoStart, autoRestart
Session
Individual conversation context with message history.
Operations: send(), sendAndWait(), on(), abort(), getMessages(), destroy()
Config: model, streaming, tools, systemMessage
Events
Key events during processing:
| Event | Purpose |
|---|---|
assistant.message |
Complete response |
assistant.message_delta |
Streaming chunk |
session.idle |
Ready for next prompt |
tool.execution_start/end |
Tool invocations |
For full event lifecycle and SessionEvent structure, see references/event-system.md.
Streaming
streaming: false(default) - Content arrives all at oncestreaming: true- Content arrives incrementally viaassistant.message_delta
Final assistant.message always fires regardless of streaming setting.
Available Models
See Supported AI Models for full list.
| Provider | Model ID | Notes |
|---|---|---|
| OpenAI | gpt-4.1, gpt-5, gpt-5-mini |
Included |
| OpenAI | gpt-5.1, gpt-5.1-codex, gpt-5.2 |
Premium |
| Anthropic | claude-sonnet-4.5 |
Premium (CLI default) |
| Anthropic | claude-opus-4.5 |
Premium (3× multiplier) |
gemini-3-pro-preview |
Premium |
Custom Tools
TypeScript (Zod):
const tool = defineTool("lookup_issue", {
description: "Fetch issue details",
parameters: z.object({ id: z.string() }),
handler: async ({ id }) => fetchIssue(id),
});
Python (Pydantic):
@define_tool(description="Fetch issue details")
async def lookup_issue(params: IssueParams) -> dict:
return fetch_issue(params.id)
For complete tool examples in all languages, see references/working-examples.md.
Language Conventions
| Concept | TypeScript | Python | Go | .NET |
|---|---|---|---|---|
| Create session | createSession() |
create_session() |
CreateSession() |
CreateSessionAsync() |
| Delta content | deltaContent |
delta_content |
DeltaContent |
DeltaContent |
For full conventions table, see references/event-system.md.
CLI Configuration
Config stored in ~/.copilot/:
config.json- General configurationmcp-config.json- MCP server definitions
For custom agents and MCP setup, see references/cli-agents-mcp.md.
Troubleshooting
| Problem | Solution |
|---|---|
| Events fire but content empty | Use event.data.content, not event.content |
| Handler never fires | Register before send() |
| Python enum issues | Use event.type.value |
| Go nil pointer | Check != nil before dereferencing |
For debugging techniques, see references/troubleshooting.md.
Skill References
Detailed documentation in this skill:
references/working-examples.md- Complete examples for all languages, custom toolsreferences/event-system.md- Event lifecycle, SessionEvent structure, language conventionsreferences/troubleshooting.md- Common issues, debugging techniquesreferences/cli-agents-mcp.md- CLI configuration, custom agents, MCP server setup
Additional Resources
Discussion
Product Hunt–style comments (not star reviews)- No comments yet — start the thread.
Ratings
4.5★★★★★65 reviews- ★★★★★Diego Smith· Dec 28, 2024
Solid pick for teams standardizing on skills: copilot-sdk is focused, and the summary matches what you get after install.
- ★★★★★William Khan· Dec 28, 2024
I recommend copilot-sdk for anyone iterating fast on agent tooling; clear intent and a small, reviewable surface area.
- ★★★★★Valentina Flores· Dec 8, 2024
copilot-sdk is among the better-maintained entries we tried; worth keeping pinned for repeat workflows.
- ★★★★★Kwame Rahman· Dec 8, 2024
Registry listing for copilot-sdk matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Shikha Mishra· Dec 4, 2024
Registry listing for copilot-sdk matched our evaluation — installs cleanly and behaves as described in the markdown.
- ★★★★★Mateo Ramirez· Dec 4, 2024
We added copilot-sdk from the explainx registry; install was straightforward and the SKILL.md answered most questions upfront.
- ★★★★★Arjun Abebe· Dec 4, 2024
Useful defaults in copilot-sdk — fewer surprises than typical one-off scripts, and it plays nicely with `npx skills` flows.
- ★★★★★Layla Brown· Dec 4, 2024
Solid pick for teams standardizing on skills: copilot-sdk is focused, and the summary matches what you get after install.
- ★★★★★Isabella Martinez· Nov 27, 2024
Keeps context tight: copilot-sdk is the kind of skill you can hand to a new teammate without a long onboarding doc.
- ★★★★★Rahul Santra· Nov 23, 2024
Keeps context tight: copilot-sdk is the kind of skill you can hand to a new teammate without a long onboarding doc.
showing 1-10 of 65