Вы можете подключить репозиторий GitHub к контейнеру сеанса и подключиться к GitHub MCP для создания запросов на слияние.
Репозитории GitHub кэшируются, поэтому будущие сеансы, использующие один и тот же репозиторий, запускаются быстрее.
Все запросы Managed Agents API требуют заголовка бета-версии managed-agents-2026-04-01. SDK автоматически устанавливает заголовок бета-версии.
Сначала создайте агента, который объявляет сервер GitHub MCP. Определение агента содержит URL сервера, но не содержит токена аутентификации:
AGENT_ID=$(ant beta:agents create \
--name "Code Reviewer" \
--model '{id: claude-opus-4-7}' \
--system "You are a code review assistant with access to GitHub." \
--mcp-server '{type: url, name: github, url: https://api.githubcopilot.com/mcp/}' \
--tool '{type: agent_toolset_20260401}' \
--tool '{type: mcp_toolset, mcp_server_name: github}' \
--transform id --raw-output)Затем создайте сеанс, который подключает репозиторий GitHub:
session = client.beta.sessions.create(
agent=agent.id,
environment_id=environment.id,
resources=[
{
"type": "github_repository",
"url": "https://github.com/org/repo",
"mount_path": "/workspace/repo",
"authorization_token": "ghp_your_github_token",
},
],
)resources[].authorization_token аутентифицирует операцию клонирования репозитория и не отражается в ответах API.
При предоставлении токена GitHub используйте минимально необходимые разрешения:
| Действие | Требуемые области |
|---|---|
| Клонирование приватных репозиториев | repo |
| Создание PR | repo |
| Чтение проблем | repo (приватный) или public_repo |
| Создание проблем | repo (приватный) или public_repo |
Используйте детализированные личные токены доступа с минимально необходимыми разрешениями. Избегайте использования токенов с широким доступом к вашей учетной записи GitHub.
Подключите несколько репозиториев, добавив записи в массив resources:
resources = [
{
"type": "github_repository",
"url": "https://github.com/org/frontend",
"mount_path": "/workspace/frontend",
"authorization_token": "ghp_your_github_token",
},
{
"type": "github_repository",
"url": "https://github.com/org/backend",
"mount_path": "/workspace/backend",
"authorization_token": "ghp_your_github_token",
},
]После создания сеанса вы можете перечислить его ресурсы репозитория и ротировать их токены авторизации. Каждый ресурс имеет id, возвращаемый во время создания сеанса (или через resources.list), который вы используете для обновлений. Репозитории подключены на время жизни сеанса; чтобы изменить, какие репозитории подключены, создайте новый сеанс.
# List resources on the session
listed = client.beta.sessions.resources.list(session.id)
repo_resource_id = listed.data[0].id
print(repo_resource_id) # "sesrsc_01ABC..."
# Rotate the authorization token
client.beta.sessions.resources.update(
repo_resource_id,
session_id=session.id,
authorization_token="ghp_your_new_github_token",
)С сервером GitHub MCP агент может создавать ветки, фиксировать изменения и отправлять их:
client.beta.sessions.events.send(
session.id,
events=[
{
"type": "user.message",
"content": [
{
"type": "text",
"text": "Fix the type error in src/utils.ts, commit it to a new branch, and push it.",
},
],
},
],
)Was this page helpful?