Loading...
  • Разработка
  • Администрирование
  • Модели и цены
  • Клиентские SDK
  • Справочник API
Search...
⌘K
Log in
Доступ к GitHub
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...
Loading...

Solutions

  • AI agents
  • Code modernization
  • Coding
  • Customer support
  • Education
  • Financial services
  • Government
  • Life sciences

Partners

  • Amazon Bedrock
  • Google Cloud's Vertex AI

Learn

  • Blog
  • Courses
  • Use cases
  • Connectors
  • Customer stories
  • Engineering at Anthropic
  • Events
  • Powered by Claude
  • Service partners
  • Startups program

Company

  • Anthropic
  • Careers
  • Economic Futures
  • Research
  • News
  • Responsible Scaling Policy
  • Security and compliance
  • Transparency

Learn

  • Blog
  • Courses
  • Use cases
  • Connectors
  • Customer stories
  • Engineering at Anthropic
  • Events
  • Powered by Claude
  • Service partners
  • Startups program

Help and security

  • Availability
  • Status
  • Support
  • Discord

Terms and policies

  • Privacy policy
  • Responsible disclosure policy
  • Terms of service: Commercial
  • Terms of service: Consumer
  • Usage policy
Разработка/Делегирование работы агенту

Доступ к GitHub

Подключите вашего агента к репозиториям GitHub для клонирования, чтения и создания запросов на слияние.

Вы можете подключить репозиторий GitHub к контейнеру сеанса и подключиться к GitHub MCP для создания запросов на слияние.

Репозитории GitHub кэшируются, поэтому будущие сеансы, использующие один и тот же репозиторий, запускаются быстрее.

Все запросы Managed Agents API требуют заголовка бета-версии managed-agents-2026-04-01. SDK автоматически устанавливает заголовок бета-версии.

GitHub MCP и ресурсы сеанса

Сначала создайте агента, который объявляет сервер 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
Создание PRrepo
Чтение проблем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?

  • GitHub MCP и ресурсы сеанса
  • Разрешения токена
  • Несколько репозиториев
  • Управление репозиториями в работающем сеансе
  • Создание запросов на слияние