Skip to main content

Sincronización manual de acciones desde GitHub.com

Para los usuarios que necesiten acceso a las acciones de GitHub.com, puedes sincronizar las acciones específicas a tu empresa.

Note

Actualmente los ejecutores hospedados por GitHub no se admiten en GitHub Enterprise Server. Puede ver más información sobre la compatibilidad futura planeada en GitHub public roadmap.

Las GitHub Actions en GitHub Enterprise Server están diseñadas para funcionar como ambientes sin acceso completo a la internet. De manera predeterminada, los flujos de trabajo no pueden usar acciones de GitHub.com y GitHub Marketplace.

Se recomienda habilitar el acceso automático a todas las acciones mediante GitHub Connect para integrar GitHub Enterprise Server con GitHub Enterprise Cloud. Consulta Habilitación del acceso automático a las acciones de GitHub.com mediante GitHub Connect.

Si quiere tener un control más estricto sobre qué acciones se permiten en su empresa, seguir esta guía para utilizar nuestra herramienta actions-sync de código abierto para sincronizar los repositorios de acciones individuales de GitHub.com a su empresa.

Cuando se actualiza GitHub Enterprise Server,, las acciones agrupadas se reemplazan automáticamente por las versiones predeterminadas del paquete de actualización. Es posible que no sean la versión más reciente disponible. Como procedimiento recomendado, si utiliza actions-sync para actualizar acciones, siempre debe volver a ejecutarse actions-sync después de cualquier actualización de GitHub Enterprise Server (principal o menor) para asegurarse de que las acciones permanecen actualizadas.

Acerca de la herramienta actions-sync

La herramienta actions-sync debe ejecutarse en una máquina que pueda acceder a la API de GitHub.com y a la API de su instancia de GitHub Enterprise Server. La máquina no necesita estar conectada a ambas al mismo tiempo.

Si la máquina tiene acceso a ambos sistemas al mismo tiempo, puede realizar la sincronización con un único comando actions-sync sync. Si solo puede acceder a un sistema a la vez, puede usar los comandos actions-sync pull y push.

La herramienta actions-sync solo puede descargar acciones de GitHub.com que estén almacenadas en repositorios públicos.

Note

La herramienta actions-sync está pensada para su uso en sistemas en los que GitHub Connect no está habilitado. Si ejecuta la herramienta en un sistema con GitHub Connect habilitado, es posible que vea el error The repository <repo_name> has been retired and cannot be reused. Esto indica que un flujo de trabajo utilizó esa acción directamente en GitHub.com y que su espacio de nombres se retiró en tu instancia de GitHub Enterprise Server. Consulta Habilitación del acceso automático a las acciones de GitHub.com mediante GitHub Connect.

Requisitos previos

  • Antes de utilizar la herramienta actions-sync, debe asegurarse de que todas las organizaciones de destino ya existen en su empresa. En el siguiente ejemplo se demuestra cómo sincronizar acciones en una organización denominada synced-actions. Consulta Crear una organización nueva desde cero.

  • Debes crear un personal access token en tu empresa que pueda crear y escribir en los repositorios de las organizaciones de destino. Consulta Administración de tokens de acceso personal.

  • Si quieres sincronizar las acciones incluidas en la organización actions en tu instancia de GitHub Enterprise Server, debes ser un propietario de la organización actions.

    Note

    De manera predeterminada, los administradores del sitio no son los propietarios de la organización agrupada actions.

    Los administradores del sitio pueden usar el comando ghe-org-admin-promote en el shell administrativo para promover a un usuario como propietario de la organización agrupada actions. Consulta Acceder al shell administrativo (SSH) y Utilidades de la ea de comandos.

    ghe-org-admin-promote -u USERNAME -o actions
    

Example: Using the actions-sync tool

This example demonstrates using the actions-sync tool to sync an individual action from GitHub.com to an enterprise instance.

Note

This example uses the actions-sync sync command, which requires concurrent access to both the GitHub.com API and your enterprise instance's API from your machine. If you can only access one system at a time, you can use the actions-sync pull and push commands. See the actions-sync README.

  1. Download and extract the latest actions-sync release for your machine's operating system.

  2. Create a directory to store cache files for the tool.

  3. In your terminal, change to the bin directory within the release directory you just extracted. For example:

    cd PATH/TO/gh_DATETIME_OS_ARCHITECTURE/bin
    
  4. Ejecute el comando actions-sync sync:

    ./actions-sync sync \
      --cache-dir "cache" \
      --destination-token "aabbccddeeffgg" \
      --destination-url "https://my-ghes-instance" \
      --repo-name "actions/stale:synced-actions/actions-stale"
    

    El comando anterior utiliza los siguientes argumentos:

    • --cache-dir: el directorio de la caché en la máquina que ejecuta el comando.

    • --destination-token: un personal access token para la instancia empresarial de destino.

    • --destination-url: la dirección URL de la instancia de empresa de destino.

    • --repo-name: el repositorio de acciones que se va a sincronizar. Este toma el formato owner/repository:destination_owner/destination_repository.

      • En el ejemplo anterior se sincroniza el repositorio actions/stale con el synced-actions/actions-stale en la instancia de empresa de destino. Debe crear la organización denominada synced-actions en su empresa antes de ejecutar el comando anterior.
      • Si omite :destination_owner/destination_repository, la herramienta usa el nombre original del propietario y del repositorio para la empresa. Antes de ejecutar el comando, debes crear una organización nueva en tu empresa, la cual empate con el nombre de propietario de la acción. Considera utilizar una organización central para almacenar las acciones sincronizadas en tu empresa, ya que esto significa que no necesitarás crear varias organizaciones nuevas si sincronizas las acciones de propietarios diferentes.
      • Puede sincronizar varias acciones reemplazando el parámetro --repo-name por --repo-name-list o --repo-name-list-file. Consulte actions-syncLÉAME.
  5. Después de que se haya creado el repositorio de acción en tu empresa, las personas en tu empresa pueden utilizar el repositorio de destino para referenciar la acción en sus flujos de trabajo. Para la acción de ejemplo que se muestra a continuación:

    uses: synced-actions/actions-stale@v1
    

    Consulta Sintaxis del flujo de trabajo para Acciones de GitHub.