Acciones de integración de GitHub
Copie un prompt de configuración con los pasos de instalación y la guía de markdown completa para este plugin.
Integra Capgo Actualizaciones en vivo con GitHub Acciones para desplegar automáticamente actualizaciones de tu aplicación cada vez que envíes code cambios. Este manual cubre la configuración de compilaciones automatizadas, pruebas y flujos de trabajo de despliegue utilizando la plataforma de CI/CD potente de GitHub.
Requisitos previos
Sección titulada “Requisitos previos”Antes de configurar la integración de GitHub Acciones, asegúrate de tener:
- A GitHub repository with your app’s source code
- Una cuenta de Capgo con una aplicación configurada
- Node.js y npm/yarn configurados en tu proyecto
- GitHub Acciones habilitadas para tu repositorio
Configurando GitHub Secretos
Sección titulada “Configurando GitHub Secretos”Paso 1: Configura Secretos de Repositorio
Sección titulada “Paso 1: Configura Secretos de Repositorio”Configura los secretos necesarios en tu repositorio GitHub:
- Navega a tu repositorio GitHub
- Ir a Configuración → Secretos y variables → Acciones
- Hacer clic Nueva clave secreta de repositorio y agrega lo siguiente:
| Nombre de la clave secreta | Valor |
|---|---|
CAPGO_TOKEN | Tu Capgo API token |
Implementación de Producción Simple
Sección titulada “Implementación de Producción Simple”Comienza con esta configuración básica que despliega a producción en cada push a la rama principal:
# Simple GitHub Actions Workflow for Capgo Live Updatesname: Deploy to Capgo
on: push: branches: - main
jobs: deploy: runs-on: ubuntu-latest steps: - name: Checkout uses: actions/checkout@v6
- name: Setup Node.js uses: actions/setup-node@v6 with: node-version: '24' cache: 'npm'
- name: Install, test and build run: | npm ci npm run test npm run build
- name: Deploy to Capgo run: | npm install -g @capgo/cli npx @capgo/cli bundle upload --channel production env: CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }} # For encrypted uploads, add: --key-data-v2 "${{ secrets.CAPGO_PRIVATE_KEY }}"Configuración Avanzada de Múltiples Canales
Sección titulada “Configuración Avanzada de Múltiples Canales”Implementaciones de rama de características
Sección titulada “Implementaciones de rama de características”Despliegue rama de características a canales temporales para pruebas:
# Feature branch deploymentname: Deploy Feature Branch to Capgo
on: push: branches: - 'feature/**'
jobs: deploy-feature: runs-on: ubuntu-latest steps: - uses: actions/checkout@v6 - uses: actions/setup-node@v6 with: node-version: '24' cache: 'npm'
- run: | npm ci npm run test npm run build
- name: Deploy to feature channel run: | CHANNEL_NAME=$(echo "${{ github.ref_name }}" | sed 's/[^a-zA-Z0-9]/-/g' | tr '[:upper:]' '[:lower:]') npm install -g @capgo/cli npx @capgo/cli channel create $CHANNEL_NAME --apikey ${{ secrets.CAPGO_TOKEN }} || true npx @capgo/cli bundle upload --apikey ${{ secrets.CAPGO_TOKEN }} --channel $CHANNEL_NAMEUsando la cifrado
Sección titulada “Usando la cifrado”Si estás utilizando Capgo's característica de cifrado, necesitarás almacenar tu clave privada de manera segura en tu entorno de CI/CD.
Después de configurar las claves de cifrado localmente, agrega tu clave privada a los secretos de GitHub:
# Display your private key content (copy this output)cat .capgo_key_v2Agregar este contenido como CAPGO_PRIVATE_KEY en tu repositorio de GitHub secretos, luego utilízalo en flujos de trabajo:
# Deploy with encryption- name: Deploy to Capgo with Encryption run: | npm install -g @capgo/cli npx @capgo/cli bundle upload --apikey ${{ secrets.CAPGO_TOKEN }} --key-data-v2 "${{ secrets.CAPGO_PRIVATE_KEY }}" --channel productionConfiguración de múltiples canales
Sección titulada “Configuración de múltiples canales”Para obtener información completa sobre la configuración y el manejo de múltiples canales de despliegue, consulte la documentación de canales.
Flujo de trabajo completo con desarrollo, solicitudes de extracción y despliegues de producción:
# Complete multi-environment workflowname: Deploy to Capgo
on: push: branches: [main, develop] pull_request: branches: [main, develop]
jobs: build: runs-on: ubuntu-latest steps: - uses: actions/checkout@v6 - uses: actions/setup-node@v6 with: node-version: '24' cache: 'npm'
- run: | npm ci npm run test npm run build
- uses: actions/upload-artifact@v6 with: name: dist path: dist/
deploy-development: if: github.ref == 'refs/heads/develop' needs: build runs-on: ubuntu-latest environment: development steps: - uses: actions/setup-node@v6 with: node-version: '24'
- uses: actions/download-artifact@v4 with: name: dist path: dist/
- run: | npm install -g @capgo/cli npx @capgo/cli bundle upload --apikey ${{ secrets.CAPGO_TOKEN }} --channel development
deploy-pr: if: github.event_name == 'pull_request' needs: build runs-on: ubuntu-latest steps: - uses: actions/setup-node@v6 with: node-version: '24'
- uses: actions/download-artifact@v4 with: name: dist path: dist/
- name: Deploy to PR channel run: | CHANNEL_NAME="pr-${{ github.event.number }}" npm install -g @capgo/cli npx @capgo/cli channel create $CHANNEL_NAME --apikey ${{ secrets.CAPGO_TOKEN }} || true npx @capgo/cli bundle upload --apikey ${{ secrets.CAPGO_TOKEN }} --channel $CHANNEL_NAME
- name: Comment PR uses: actions/github-script@v7 with: script: | github.rest.issues.createComment({ issue_number: context.issue.number, owner: context.repo.owner, repo: context.repo.repo, body: `🚀 This PR has been deployed to Capgo channel: \`pr-${{ github.event.number }}\`\n\nTo test this update in your app, configure it to use this channel. [Learn how to configure channels →](/docs/live-updates/channels/#configuring-the-channel-in-your-app)` })
deploy-production: if: github.ref == 'refs/heads/main' needs: build runs-on: ubuntu-latest environment: production steps: - uses: actions/setup-node@v6 with: node-version: '24'
- uses: actions/download-artifact@v4 with: name: dist path: dist/
- run: | npm install -g @capgo/cli npx @capgo/cli bundle upload --apikey ${{ secrets.CAPGO_TOKEN }} --channel productionLimpieza de características de canales
Sección titulada “Limpieza de canales de características”Limpieza automática de canales de características cuando se eliminan ramas:
name: Cleanup Feature Channels
on: delete:
jobs: cleanup: runs-on: ubuntu-latest if: github.event.ref_type == 'branch' && startsWith(github.event.ref, 'feature/') steps: - uses: actions/setup-node@v6 with: node-version: '24'
- name: Delete Capgo channel run: | CHANNEL_NAME=$(echo "${{ github.event.ref }}" | sed 's/[^a-zA-Z0-9]/-/g' | tr '[:upper:]' '[:lower:]') npm install -g @capgo/cli npx @capgo/cli channel delete $CHANNEL_NAME --apikey ${{ secrets.CAPGO_TOKEN }} || trueSeguridad y Mejores Prácticas
Sección titulada “Seguridad y Mejores Prácticas”Reglas de protección del entorno
Sección titulada “Reglas de protección del entorno”Configura reglas de protección del entorno en GitHub:
- Ir a Configuración → Entornos en tu repositorio
- Crear entornos:
development,staging,production - Para el entorno de producción, agregue:
- Revisores requeridos: Agregue a los miembros del equipo que deben aprobar los despliegues
- Retraso de espera: Agregue un retraso antes del despliegue (opcional)
- Ramas de despliegue: Restringir a
mainrama solo
Gestión de secretos seguros
Título de la sección “Gestión de secretos seguros”Usar secretos específicos del entorno:
# Use different secrets per environmentdeploy-production: environment: production steps: - name: Deploy to Production run: | npx @capgo/cli bundle upload \ --apikey ${{ secrets.CAPGO_PROD_TOKEN }} \ --app ${{ secrets.CAPGO_PROD_APP_ID }} \ --channel productionMonitoreo y Notificaciones
Sección titulada “Monitoreo y Notificaciones”Integración de Slack
Sección titulada “Integración de Slack”Agregar notificaciones de Slack a tu flujo de trabajo:
name: Deploy with Notifications
jobs: deploy: runs-on: ubuntu-latest steps: # ... deployment steps
- name: Notify Slack on Success if: success() uses: 8398a7/action-slack@v3 with: status: success text: '✅ Capgo deployment successful!' fields: repo,message,commit,author,action,eventName,ref,workflow env: SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}
- name: Notify Slack on Failure if: failure() uses: 8398a7/action-slack@v3 with: status: failure text: '❌ Capgo deployment failed!' fields: repo,message,commit,author,action,eventName,ref,workflow env: SLACK_WEBHOOK_URL: ${{ secrets.SLACK_WEBHOOK_URL }}Integración de Discord
Sección titulada “Integración de Discord”Enviar notificaciones a Discord:
- name: Discord notification if: always() uses: Ilshidur/action-discord@master with: args: | Capgo deployment ${{ job.status }}! App: ${{ secrets.CAPGO_APP_ID }} Channel: ${{ github.ref_name }} Commit: ${{ github.sha }} env: DISCORD_WEBHOOK: ${{ secrets.DISCORD_WEBHOOK }}Notificaciones por Correo Electrónico
Sección titulada “Notificaciones por Correo”Configurar notificaciones por correo:
- name: Send email notification if: failure() uses: dawidd6/action-send-mail@v3 with: server_address: smtp.gmail.com server_port: 465 username: ${{ secrets.EMAIL_USERNAME }} password: ${{ secrets.EMAIL_PASSWORD }} subject: 'Capgo Deployment Failed - ${{ github.repository }}' to: team@yourcompany.com from: ci-cd@yourcompany.com body: | Deployment failed for ${{ github.repository }} Branch: ${{ github.ref_name }} Commit: ${{ github.sha }} Workflow: ${{ github.workflow }}Resolución de Problemas
Sección titulada “Resolución de Problemas”Flujo de Depuración
Sección titulada “Flujo de Depuración”Agregar pasos de depuración para resolver problemas:
- name: Debug environment run: | echo "Node version: $(node --version)" echo "NPM version: $(npm --version)" echo "Working directory: $(pwd)" echo "Files in dist/: $(ls -la dist/ || echo 'No dist directory')" echo "Environment variables:" env | grep -E "(GITHUB_|CAPGO_)" | sort
- name: Test Capgo CLI run: | npx @capgo/cli --version npx @capgo/cli app debug --apikey ${{ secrets.CAPGO_TOKEN }} --app ${{ secrets.CAPGO_APP_ID }}Problemas Comunes y Soluciones
Sección titulada “Problemas Comunes y Soluciones”El flujo de trabajo falla con “CAPGO_TOKEN no encontrado”
- name: Verify secrets run: | if [ -z "${{ secrets.CAPGO_TOKEN }}" ]; then echo "ERROR: CAPGO_TOKEN secret is not set" exit 1 fi echo "CAPGO_TOKEN is set (length: ${#CAPGO_TOKEN})" env: CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }}No se encontraron artefactos de construcción:
- name: Debug artifacts run: | echo "Checking for build artifacts..." ls -la dist/ || echo "No dist directory found" find . -name "*.js" -o -name "*.html" | head -10Problemas de conectividad de red:
- name: Test connectivity run: | ping -c 3 api.capgo.io || echo "Ping failed" curl -I https://api.capgo.io/health || echo "Health check failed"Flujos de trabajo reutilizables
Sección titulada “Flujos de trabajo reutilizables”Crea flujos de trabajo reutilizables para consistencia en proyectos:
name: Reusable Capgo Deploy
on: workflow_call: inputs: environment: required: true type: string channel: required: true type: string secrets: CAPGO_TOKEN: required: true CAPGO_APP_ID: required: true
jobs: deploy: runs-on: ubuntu-latest environment: ${{ inputs.environment }} steps: - uses: actions/checkout@v6
- name: Setup Node.js uses: actions/setup-node@v6 with: node-version: '24' cache: 'npm'
- name: Install and build run: | npm ci npm run build
- name: Deploy to Capgo run: | npm install -g @capgo/cli npx @capgo/cli bundle upload \ --apikey ${{ secrets.CAPGO_TOKEN }} \ --app ${{ secrets.CAPGO_APP_ID }} \ --channel ${{ inputs.channel }}Utiliza el flujo de trabajo reutilizable:
name: Deploy App
on: push: branches: [main, develop]
jobs: deploy-dev: if: github.ref == 'refs/heads/develop' uses: ./.github/workflows/reusable-capgo-deploy.yml with: environment: development channel: development secrets: CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }} CAPGO_APP_ID: ${{ secrets.CAPGO_APP_ID }}
deploy-prod: if: github.ref == 'refs/heads/main' uses: ./.github/workflows/reusable-capgo-deploy.yml with: environment: production channel: production secrets: CAPGO_TOKEN: ${{ secrets.CAPGO_TOKEN }} CAPGO_APP_ID: ${{ secrets.CAPGO_APP_ID }}Pasos siguientes
Sección titulada “Pasos siguientes”- Aprende sobre Canales para gestionar diferentes entornos de despliegue
- Explora Almacenamiento personalizado para escenarios de despliegue avanzados
- Configura Cifrado para despliegues seguros
- Configure Actualizar comportamiento para personalizar cómo se aplican las actualizaciones
Con la integración de GitHub Actions, puede aprovechar el poderoso plataforma de CI/CD de GitHub para crear complejos flujos de trabajo de despliegue con características de seguridad, monitoreo y colaboración integradas para sus actualizaciones en vivo de Capgo.
Continuar desde la integración de GitHub Actions
Título de la sección “Continuar desde la integración de GitHub Actions”Si está utilizando La integración de GitHub Actions para planificar la automatización de CI/CD, conecte con La integración de Capgo de CI/CD para el flujo de trabajo del producto en la integración de Capgo de CI/CD, La integración de Capgo de compilaciones nativas para el flujo de trabajo del producto en Capgo Compilaciones Nativas, Capgo Integraciones para el flujo de trabajo del producto en Capgo Integraciones, Integración CI/CD para el detalle de implementación en Integración CI/CD, y Integración CI/CD de GitLab para el detalle de implementación en Integración CI/CD de GitLab.