Awesome-omni-skill copilot-sdk
This skill provides guidance for creating agents and applications with the GitHub Copilot SDK. IMPORTANT - When using the SDK with TypeScript/Node.js, the project MUST use ESM (ECMAScript Modules). CommonJS (require/module.exports) is NOT supported. It should be used when the user wants to create, modify, or work on software that uses the GitHub Copilot SDK in TypeScript (ESM only), Python, Go, or .NET. The skill covers SDK usage patterns, ESM-based project configuration, CLI configuration, custom tools, MCP servers, and custom agents.
git clone https://github.com/diegosouzapw/awesome-omni-skill
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/development/copilot-sdk-doggy8088" ~/.claude/skills/diegosouzapw-awesome-omni-skill-copilot-sdk-2e935e && rm -rf "$T"
skills/development/copilot-sdk-doggy8088/SKILL.mdGitHub 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.
Critical Constraint (TypeScript / Node.js):
- The Copilot SDK for Node.js is ESM-only
- Projects MUST use ECMAScript Modules
- CommonJS (
,require
) is not supportedmodule.exports
Status: Technical Preview (suitable for development and testing)
Supported Languages: TypeScript/Node.js (ESM only), 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+ (ESM required)
- Python 3.8+
- Go 1.21+
- .NET 8.0+
-
TypeScript / Node.js Project Requirements
MUST include:package.json{ "type": "module" }- Use
/importexport - Do NOT use
orrequire()module.exports
Installation
| Language | Command |
|---|---|
| TypeScript/Node.js (ESM) | |
| Python | |
| Go | |
| .NET | |
Architecture
Application (ESM) → 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 – ESM REQUIRED)
// package.json MUST include: { "type": "module" } 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:
- ESM only (
)import - No CommonJS
- Register event handlers before calling
send()
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 |
|---|---|
| Complete response |
| Streaming chunk |
| Ready for next prompt |
| Tool invocations |
For full event lifecycle and SessionEvent structure, see
references/event-system.md.
Streaming
(default) - Content arrives all at oncestreaming: false
- Content arrives incrementally viastreaming: trueassistant.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 | , , | Included |
| OpenAI | , , | Premium |
| Anthropic | | Premium (CLI default) |
| Anthropic | | Premium (3× multiplier) |
| Premium |
Custom Tools
TypeScript (ESM + 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 (ESM) | Python | Go | .NET |
|---|---|---|---|---|
| Create session | | | | |
| Delta content | | | | |
For full conventions table, see
references/event-system.md.
CLI Configuration
Config stored in
~/.copilot/:
- General configurationconfig.json
- MCP server definitionsmcp-config.json
For custom agents and MCP setup, see
references/cli-agents-mcp.md.
Troubleshooting
| Problem | Solution |
|---|---|
| Import errors | Ensure ESM () |
| Events fire but content empty | Use , not |
| Handler never fires | Register before |
| Python enum issues | Use |
| Go nil pointer | Check before dereferencing |
For debugging techniques, see
references/troubleshooting.md.
Skill References
Detailed documentation in this skill:
- Complete examples for all languages, custom toolsreferences/working-examples.md
- Event lifecycle, SessionEvent structure, language conventionsreferences/event-system.md
- Common issues, debugging techniquesreferences/troubleshooting.md
- CLI configuration, custom agents, MCP server setupreferences/cli-agents-mcp.md