The GitHub Copilot SDK supports multiple authentication methods to fit different use cases. Choose the method that best matches your deployment scenario.
| Method | Use Case | Copilot Subscription Required |
|---|---|---|
| GitHub Signed-in User | Interactive apps where users sign in with GitHub | Yes |
| OAuth GitHub App | Apps acting on behalf of users via OAuth | Yes |
| Environment Variables | CI/CD, automation, server-to-server | Yes |
| BYOK (Bring Your Own Key) | Using your own API keys (Azure AI Foundry, OpenAI, etc.) | No |
This is the default authentication method when running the Copilot CLI interactively. Users authenticate via GitHub OAuth device flow, and the SDK uses their stored credentials.
How it works:
- User runs
copilotCLI and signs in via GitHub OAuth - Credentials are stored securely in the system keychain
- SDK automatically uses stored credentials
SDK Configuration:
Node.js / TypeScript
import { CopilotClient } from "@github/copilot-sdk";
// Default: uses logged-in user credentials
const client = new CopilotClient();Python
from copilot import CopilotClient
# Default: uses logged-in user credentials
client = CopilotClient()
await client.start()Go
package main
import copilot "github.com/github/copilot-sdk/go"
func main() {
// Default: uses logged-in user credentials
client := copilot.NewClient(nil)
_ = client
}import copilot "github.com/github/copilot-sdk/go"
// Default: uses logged-in user credentials
client := copilot.NewClient(nil).NET
using GitHub.Copilot.SDK;
// Default: uses logged-in user credentials
await using var client = new CopilotClient();When to use:
- Desktop applications where users interact directly
- Development and testing environments
- Any scenario where a user can sign in interactively
Use an OAuth GitHub App to authenticate users through your application and pass their credentials to the SDK. This enables your application to make Copilot API requests on behalf of users who authorize your app.
How it works:
- User authorizes your OAuth GitHub App
- Your app receives a user access token (
gho_orghu_prefix) - Pass the token to the SDK via
githubTokenoption
SDK Configuration:
Node.js / TypeScript
import { CopilotClient } from "@github/copilot-sdk";
const client = new CopilotClient({
githubToken: userAccessToken, // Token from OAuth flow
useLoggedInUser: false, // Don't use stored CLI credentials
});Python
from copilot import CopilotClient
client = CopilotClient({
"github_token": user_access_token, # Token from OAuth flow
"use_logged_in_user": False, # Don't use stored CLI credentials
})
await client.start()Go
package main
import copilot "github.com/github/copilot-sdk/go"
func main() {
userAccessToken := "token"
client := copilot.NewClient(&copilot.ClientOptions{
GitHubToken: userAccessToken,
UseLoggedInUser: copilot.Bool(false),
})
_ = client
}import copilot "github.com/github/copilot-sdk/go"
client := copilot.NewClient(&copilot.ClientOptions{
GithubToken: userAccessToken, // Token from OAuth flow
UseLoggedInUser: copilot.Bool(false), // Don't use stored CLI credentials
}).NET
using GitHub.Copilot.SDK;
var userAccessToken = "token";
await using var client = new CopilotClient(new CopilotClientOptions
{
GithubToken = userAccessToken,
UseLoggedInUser = false,
});using GitHub.Copilot.SDK;
await using var client = new CopilotClient(new CopilotClientOptions
{
GithubToken = userAccessToken, // Token from OAuth flow
UseLoggedInUser = false, // Don't use stored CLI credentials
});Supported token types:
gho_- OAuth user access tokensghu_- GitHub App user access tokensgithub_pat_- Fine-grained personal access tokens
Not supported:
ghp_- Classic personal access tokens (deprecated)
When to use:
- Web applications where users sign in via GitHub
- SaaS applications building on top of Copilot
- Any multi-user application where you need to make requests on behalf of different users
For automation, CI/CD pipelines, and server-to-server scenarios, you can authenticate using environment variables.
Supported environment variables (in priority order):
COPILOT_GITHUB_TOKEN- Recommended for explicit Copilot usageGH_TOKEN- GitHub CLI compatibleGITHUB_TOKEN- GitHub Actions compatible
How it works:
- Set one of the supported environment variables with a valid token
- The SDK automatically detects and uses the token
SDK Configuration:
No code changes needed—the SDK automatically detects environment variables:
Node.js / TypeScript
import { CopilotClient } from "@github/copilot-sdk";
// Token is read from environment variable automatically
const client = new CopilotClient();Python
from copilot import CopilotClient
# Token is read from environment variable automatically
client = CopilotClient()
await client.start()When to use:
- CI/CD pipelines (GitHub Actions, Jenkins, etc.)
- Automated testing
- Server-side applications with service accounts
- Development when you don't want to use interactive login
BYOK allows you to use your own API keys from model providers like Azure AI Foundry, OpenAI, or Anthropic. This bypasses GitHub Copilot authentication entirely.
Key benefits:
- No GitHub Copilot subscription required
- Use enterprise model deployments
- Direct billing with your model provider
- Support for Azure AI Foundry, OpenAI, Anthropic, and OpenAI-compatible endpoints
See the BYOK documentation for complete details, including:
- Azure AI Foundry setup
- Provider configuration options
- Limitations and considerations
- Complete code examples
When multiple authentication methods are available, the SDK uses them in this priority order:
- Explicit
githubToken- Token passed directly to SDK constructor - HMAC key -
CAPI_HMAC_KEYorCOPILOT_HMAC_KEYenvironment variables - Direct API token -
GITHUB_COPILOT_API_TOKENwithCOPILOT_API_URL - Environment variable tokens -
COPILOT_GITHUB_TOKEN→GH_TOKEN→GITHUB_TOKEN - Stored OAuth credentials - From previous
copilotCLI login - GitHub CLI -
gh authcredentials
To prevent the SDK from automatically using stored credentials or gh CLI auth, use the useLoggedInUser: false option:
Node.js / TypeScript
const client = new CopilotClient({
useLoggedInUser: false, // Only use explicit tokens
});Python
from copilot import CopilotClient
client = CopilotClient({
"use_logged_in_user": False,
})client = CopilotClient({
"use_logged_in_user": False, # Only use explicit tokens
})Go
package main
import copilot "github.com/github/copilot-sdk/go"
func main() {
client := copilot.NewClient(&copilot.ClientOptions{
UseLoggedInUser: copilot.Bool(false),
})
_ = client
}client := copilot.NewClient(&copilot.ClientOptions{
UseLoggedInUser: copilot.Bool(false), // Only use explicit tokens
}).NET
await using var client = new CopilotClient(new CopilotClientOptions
{
UseLoggedInUser = false, // Only use explicit tokens
});- BYOK Documentation - Learn how to use your own API keys
- Getting Started Guide - Build your first Copilot-powered app
- MCP Servers - Connect to external tools