Skip to main content

Управление доступом к миграции с сервера Bitbucket

Прежде чем использовать GitHub Enterprise Importer, убедитесь, что у вас есть соответствующий доступ к источнику и назначению миграции.

О требуемом доступе для GitHub Enterprise Importer

Для защиты данных GitHub применяет определенные требования к доступу для использования GitHub Enterprise Importer. Эти требования зависят от выполняемой задачи. Чтобы предотвратить ошибки, необходимо внимательно просмотреть эту статью и убедиться, что выполнены все требования для задачи, которую вы хотите завершить.

Чтобы перенести репозиторий из Bitbucket Server в GitHub, вам нужен достаточный доступ к источнику (экземпляру сервера Bitbucket) и назначению (организация на GitHub). Чтобы получить достаточный доступ, вам потребуется все перечисленные ниже действия.

  • Требуемая роль в целевой организации на GitHub
  • personal access token с доступом к целевой организации на GitHub
    • Данные personal access token должны иметь все необходимые области, которые зависят от роли и задачи, которую вы хотите завершить.
    • Если целевая организация использует единый вход SAML для GitHub, необходимо авторизовать personal access token для единого входа.
  • На сервере Bitbucket необходимые разрешения и доступ SFTP или SMB

Кроме того, при использовании списков разрешенных IP-адресов в целевой организации может потребоваться настроить списки разрешений, чтобы разрешить доступ к данным GitHub Enterprise Importer.

Сведения о роли миграции

Обязательные роли для GitHub

Для целевой организации на GitHubдля разных задач требуются разные роли.

Обязательные области для personal access tokens

Для выполнения миграции требуется personal access token для доступа к целевой организации на GitHub.

Области, необходимые для ваших GitHub personal access token (classic) зависят от вашей роли и задачи, которую вы хотите завершить.

Note

Можно использовать только personal access token (classic), а не fine-grained personal access token. Это означает, что вы не можете использовать GitHub Enterprise Importer, если в вашей организации используется политика "Ограничить доступ к данным personal access tokens (classic)". Дополнительные сведения см. в разделе Применение политик для персональных маркеров доступа в вашей организации.

ЗадачаВладелец организацииСредство переноса
Назначение роли миграции для миграций репозиторияadmin:org
Выполнение миграции репозитория (целевая организация)repo, , admin:org``workflowrepo, , read:org``workflow
Скачивание журнала миграцииrepo, , admin:org``workflowrepo, , read:org``workflow
Восстановление манекеновadmin:org

Необходимые разрешения для сервера Bitbucket

Чтобы выполнить миграцию с Bitbucket Server, вам потребуется:

  • Имя пользователя и пароль учетной записи Сервера Bitbucket с разрешениями администратора или суперадминистратором
  • Если экземпляры сервера Bitbucket выполняются в Linux, SFTP-доступ к экземпляру сервера Bitbucket (см . ключи SSH). Как правило, если вы можете получить доступ к серверу через SSH, можно также использовать SFTP.
  • Если экземпляр Сервера Bitbucket работает в Windows, доступ к экземпляру Сервера Bitbucket (SMB)

Ключи SSH

Если экземпляр Bitbucket Server работает в Linux, необходимо использовать ключ SSH, соответствующий следующим требованиям:

  • Не имеет парольной фразы
  • Использует один из следующих шифров
    • aes256-ctr
    • 3des-cbc
    • aes128-cbc
    • aes192-cbc
    • aes256-cbc
    • blowfish-cbc
    • twofish-cbc
    • twofish192-cbc
    • twofish128-cbc
    • twofish256-cbc
    • arcfour
    • arcfour128
    • arcfour256
    • cast128-cbc
    • aes128-ctr
    • aes192-ctr

Если при выполнении миграции возникает ошибка cipher name aes256-ctr for openssh key file is not supported , закрытый ключ SSH использует неподдерживаемый шифр. Дополнительные сведения о создании совместимого закрытого ключа см. в разделе Устранение неполадок миграции с помощью GitHub Enterprise Importer.

Предоставление роли миграции

Чтобы разрешить другим пользователям, кроме владелец организации выполнять миграцию или скачивать журналы миграции, вы можете предоставить роль миграции пользователю или группе. Дополнительные сведения см. в разделе "Сведения о роли миграции".

Вы можете предоставить роль миграции с помощью BBS2GH extension of the GitHub CLI или API GraphQL.

Предоставление роли миграции с помощью BBS2GH extension

Чтобы предоставить роль миграции с помощью ИНТЕРФЕЙСА командной строки, необходимо установить BBS2GH extension of the GitHub CLI. Дополнительные сведения см. в разделе Перенос репозиториев из Bitbucket Server в GitHub Enterprise Cloud.

  1. На GitHubсоздайте и запишите personal access token, которая соответствует всем требованиям для предоставления роли миграции. Дополнительные сведения см. в статье "Создание personal access token для GitHub Enterprise Importer.

  2. gh bbs2gh grant-migrator-role Используйте команду, заменив организацию организацией, для которой вы хотите предоставить роль миграции, СУБЪЕКТу имя пользователя или команды и ТИП.USER TEAM

    Shell
    gh bbs2gh grant-migrator-role --github-org ORGANIZATION --actor ACTOR --actor-type TYPE
    

Предоставление роли миграции с помощью API GraphQL

Создание personal access token для GitHub Enterprise Importer

  1. Убедитесь, что у вас есть достаточная роль для задачи, которую вы хотите завершить. Дополнительные сведения см. в разделе "Обязательные роли".
  2. Создайте personal access token (classic), чтобы предоставить все области, необходимые для выполнения задачи. Можно использовать только personal access token (classic), а не fine-grained personal access token. Дополнительные сведения: Управление личными маркерами доступа и обязательные области для personal access token.
  3. Если единый вход SAML применяется для организаций, к ним необходимо получить доступ, авторизуйте personal access token для единого входа. Дополнительные сведения см. в разделе Авторизация личного токена доступа для использования с документами единого входа SAML.

Настройка списков разрешений IP-адресов для миграций

Если назначение миграции использует список разрешенных IP-адресов (GitHubфункции списка разрешений IP-адресов или ip-адреса поставщика удостоверений (Поставщик удостоверений), необходимо настроить списки разрешений IP на GitHub.

  • Если вы используете функцию списка разрешений IP-адресов GitHub, необходимо добавить диапазоны IP-адресов GitHub ниже в список разрешений для целевой организации.
  • Если вы используете список разрешений поставщика удостоверений для ограничения доступа к вашей организации на GitHub, эти ограничения следует отключить в параметрах учетной записи предприятия до завершения миграции.

Дополнительные сведения см. в разделе [AUTOTITLE и Управление разрешенными IP-адресами для организации](/enterprise-cloud@latest/admin/configuration/configuring-your-enterprise/restricting-network-traffic-to-your-enterprise-with-an-ip-allow-list).

Диапазоны IP-адресов для GitHub.com

Вам потребуется добавить следующие диапазоны IP-адресов в список разрешений IP-адресов.

  • 192.30.252.0/22
  • 185.199.108.0/22
  • 140.82.112.0/20
  • 143.55.64.0/20
  • 40.71.233.224/28
  • 2a0a:a440::/29
  • 2606:50c0::/32
  • 20.125.12.8/29 (активно с 00:00 UTC 8 ноября 2023 г.)

Вы можете получить актуальный список диапазонов IP-адресов, используемых GitHub Enterprise Importer в любое время с помощью конечной точки "Получить метаданные GitHub" REST API.

Ключ github_enterprise_importer в ответе содержит список диапазонов IP-адресов, используемых для миграции.

Дополнительные сведения см. в разделе Конечные точки REST API для метаданных.

Диапазоны IP-адресов для GHE.com

Необходимо разрешить:

  • Диапазоны, необходимые для всех
  • Дополнительные диапазоны, зависящие от региона расположения данных

Дополнительные диапазоны см. в разделе Сведения о сети для GHE.com.

Кроме того, если вы используете учетную запись хранения BLOB-объектов с правилами брандмауэра:

  • Необходимо разрешить доступ к диапазонам IP-адресов исходящего трафика для GHE.com. См . раздел AUTOTITLE.
  • Если вы используете Хранилище BLOB-объектов Azure, может потребоваться выполнить дополнительную настройку. Обратитесь к Служба поддержки GitHub.

Дополнительные материалы