Методы аутентификации
| Метод | Вариант использования | Требуется подписка на Copilot |
|---|---|---|
| GitHub Авторизованный пользователь | Интерактивные приложения, в которые пользователи входят через GitHub | Yes |
| OAuth GitHub приложение | Приложения, действующие от имени пользователей через OAuth | Yes |
| Переменные среды | CI/CD, автоматизация, сервер-сервер | Yes |
| BYOK (bring your own key) | Используя собственные API-ключи (Azure AI Foundry, OpenAI и др.) | Нет |
Пользователь GitHub, вошедший в систему
Это стандартный метод аутентификации при интерактивном запуске Copilot CLI. Пользователи аутентифицируются через поток устройств GitHub OAuth, а SDK использует их сохранённые учетные данные.
Принцип работы.
- Пользователь запускает CLI
copilotи входит через GitHub OAuth - Учетные данные надёжно хранятся в системном ключе
- SDK автоматически использует сохранённые учетные данные
Конфигурация SDK:
import { CopilotClient } from "@github/copilot-sdk";
// Default: uses logged-in user credentials
const client = new CopilotClient();
from copilot import CopilotClient
# Default: uses logged-in user credentials
client = CopilotClient()
await client.start()
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)
using GitHub.Copilot;
// Default: uses logged-in user credentials
await using var client = new CopilotClient();
import com.github.copilot.sdk.CopilotClient;
// Default: uses logged-in user credentials
var client = new CopilotClient();
client.start().get();
Когда использовать:
- Настольные приложения, где пользователи взаимодействуют напрямую
- среды для разработки и тестирования;
- Любой сценарий, когда пользователь может войти интерактивно
OAuth GitHub App
Используйте приложение OAuth GitHub для аутентификации пользователей через ваше приложение и передачи их учетных данных SDK. Это позволяет вашему приложению делать запросы на Copilot API от имени пользователей, которые авторизируют ваше приложение.
Принцип работы.
- Пользователь авторизирует ваше приложение OAuth GitHub
- Ваше приложение получает пользовательский токен доступа (
gho_илиghu_префикс) - Передайте токен SDK через
gitHubTokenопцию
Конфигурация SDK:
import { CopilotClient } from "@github/copilot-sdk";
const client = new CopilotClient({
gitHubToken: userAccessToken, // Token from OAuth flow
useLoggedInUser: false, // Don't use stored CLI credentials
});
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()
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
})
using GitHub.Copilot;
var userAccessToken = "token";
await using var client = new CopilotClient(new CopilotClientOptions
{
GitHubToken = userAccessToken,
UseLoggedInUser = false,
});
using GitHub.Copilot;
await using var client = new CopilotClient(new CopilotClientOptions
{
GitHubToken = userAccessToken, // Token from OAuth flow
UseLoggedInUser = false, // Don't use stored CLI credentials
});
import com.github.copilot.sdk.CopilotClient;
import com.github.copilot.sdk.json.*;
var client = new CopilotClient(new CopilotClientOptions()
.setGitHubToken(userAccessToken) // Token from OAuth flow
.setUseLoggedInUser(false) // Don't use stored CLI credentials
);
client.start().get();
Поддерживаемые типы токенов:
gho_- Токены доступа пользователей OAuthghu_- GitHub Токены доступа пользователей приложенияgithub_pat_- Детализированные персональные токены доступа
Не поддерживаются:
ghp_- Классические личные токены доступа (устарели)
Когда использовать:
- Веб-приложения, в которых пользователи входят через GitHub
- SaaS-приложения, построенные поверх Copilot
- Любое многопользовательское приложение, где нужно делать запросы от имени разных пользователей
Переменные среды
Для автоматизации, CI/CD конвейеров и сценариев сервер-сервер можно аутентифицировать с помощью переменных среды.
Поддерживаемые переменные среды (в порядке приоритета):
COPILOT_GITHUB_TOKEN— рекомендуется для явного Copilot использованияGH_TOKEN— совместим с GitHub CLIGITHUB_TOKEN- GitHub Actions совместим
Принцип работы.
- Установите одну из поддерживаемых переменных среды с действительным токеном
- SDK автоматически обнаруживает и использует токен
Конфигурация SDK:
Изменения кода не требуются — SDK автоматически обнаруживает переменные среды:
import { CopilotClient } from "@github/copilot-sdk";
// Token is read from environment variable automatically
const client = new CopilotClient();
from copilot import CopilotClient
# Token is read from environment variable automatically
client = CopilotClient()
await client.start()
Когда использовать:
- CI/CD конвейеры (GitHub Actions, Jenkins и др.)
- Автоматическое тестирование
- Серверные приложения с сервисными аккаунтами
- Разработка, когда вы не хотите использовать интерактивный вход
БЁК (принеси свой ключ)
BYOK позволяет использовать собственные API ключи от поставщиков моделей, таких как Azure AI Foundry, OpenAI или Anthropic. Это полностью обходит аутентификацию GitHub Copilot.
Ключевые преимущества:
- Не требуется подписка на GitHub Copilot
- Использование корпоративных моделей
- Прямое выставление счетов у вашего поставщика модели
- Поддержка совместимых с Azure AI Foundry, OpenAI, Anthropic и OpenAI конечных точек
Полная информация см. BYOK (bring your own key), включая:
- Настройка Azure AI Foundry
- Параметры конфигурации поставщика
- Ограничения и рекомендации
- Полные примеры кода
Приоритет аутентификации
Когда доступно несколько методов аутентификации, SDK использует их в следующем порядке приоритета:
- Явно
gitHubToken- Токен передаётся напрямую конструктору SDK - Ключ -
CAPI_HMAC_KEYHMAC илиCOPILOT_HMAC_KEYпеременные среды - Токен прямого API -
GITHUB_COPILOT_API_TOKENсCOPILOT_API_URL - Токены -
COPILOT_GITHUB_TOKENпеременных среды →GH_TOKEN→GITHUB_TOKEN - Сохранённые учетные данные OAuth — из предыдущего
copilotвхода в CLI - GitHub CLI -
gh authквалификации
Отключение автовхода
Чтобы предотвратить автоматическое использование SDK сохранённых учетных данных или gh CLI-аутентификации, используйте useLoggedInUser: false опцию:
const client = new CopilotClient({
useLoggedInUser: false, // Only use explicit tokens
});
from copilot import CopilotClient
client = CopilotClient({
"use_logged_in_user": False,
})
client = CopilotClient({
"use_logged_in_user": False, # Only use explicit tokens
})
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
})
await using var client = new CopilotClient(new CopilotClientOptions
{
UseLoggedInUser = false, // Only use explicit tokens
});
import com.github.copilot.sdk.CopilotClient;
import com.github.copilot.sdk.json.*;
var client = new CopilotClient(new CopilotClientOptions()
.setUseLoggedInUser(false) // Only use explicit tokens
);
client.start().get();
Дальнейшие действия
- BYOK (bring your own key) — Научитесь использовать свои собственные API-ключи
- Создайте своё первое приложение на базе Copilot — Создайте своё первое приложение на базе Copilot
- Using MCP servers with the GitHub Copilot SDK — Подключение к внешним инструментам