Integrazione con Bitbucket Pipelines
Copia un prompt di configurazione con i passaggi di installazione e la guida markdown completa per questo plugin.
Integrate Capgo Live Updates with Bitbucket Pipelines to automatically deploy your app updates whenever you push code changes. This guide covers setting up automated builds, testing, and deployment workflows.
Requisiti preliminari
Sezione intitolata “Requisiti preliminari”Prima di configurare l'integrazione con Bitbucket Pipelines, assicurati di avere:
- Un account Bitbucket con un repository
- Un account Capgo con un'app configurata
- Node.js e npm/yarn configurati nel tuo progetto
Configurazione di Bitbucket Pipelines
Sezione intitolata “Configurazione di Bitbucket Pipelines”Passo 1: Configura le Variabili del Repository
Sezione intitolata “Passo 1: Configura le Variabili del Repository”In primo luogo, configura le variabili necessarie nel tuo repository Bitbucket:
- Naviga al tuo repository Bitbucket
- Vai a Impostazioni del repository → Flussi di lavoro → Variabili del repository
- Aggiungi le seguenti variabili:
| Nome della variabile | Valore | Crittografato |
|---|---|---|
CAPGO_TOKEN | Il tuo token Capgo API | ✅ Sì |
Configurazione base che distribuisce in produzione con ogni push al ramo principale:
Sezione intitolata “Simple”Configurazione di base che distribuisce in produzione con ogni push al ramo principale:
# bitbucket-pipelines.yml - Simple Configurationimage: node:22
pipelines: branches: main: - step: name: Build and Deploy to Production script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production artifacts: - dist/**Avanzato
Sezione intitolata “Avanzato”Distribuzioni di Branch di Feature
Sezione intitolata “Distribuzioni di Branch di Feature”Distribuisci le branch di feature nei canali di test per la revisione e il testing:
# Feature branch deploymentpipelines: branches: feature/*: - step: name: Deploy Feature Branch script: - npm ci - npm run test - npm run build - BRANCH_NAME=$(echo $BITBUCKET_BRANCH | sed 's/[^a-zA-Z0-9-]/-/g') - CHANNEL_NAME="feature-$BRANCH_NAME" - npm install -g @capgo/cli - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME artifacts: - dist/**Utilizzo della Crittografia
Sezione intitolata “Utilizzo della crittografia”Se stai utilizzando Capgo’s funzionalità di crittografia, avrai bisogno di memorare la tua chiave privata in modo sicuro nel tuo ambiente CI/CD.
Dopo l'installazione delle chiavi di crittografia localmente, aggiungi la tua chiave privata alle variabili di Bitbucket:
# Display your private key content (copy this output)cat .capgo_key_v2Aggiungi questo contenuto come CAPGO_PRIVATE_KEY nelle variabili del tuo repository Bitbucket (segna come sicuro), quindi utilizzalo nelle pipeline:
# Deploy with encryption- step: name: Deploy to Capgo with Encryption script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --key-data-v2 "$CAPGO_PRIVATE_KEY" --channel productionConfigurazione Multi-Canale
Sezione intitolata “Configurazione Multi-Canale”Per informazioni complete sulla configurazione e gestione di più canali di distribuzione, consulta la documentazione sui canali.
Configurazione completa con più ambienti e distribuzioni di richiesta di pull:
# bitbucket-pipelines.yml - Advanced Multi-Channel Configurationimage: node:22
definitions: steps: - step: &build-step name: Build Application script: - npm ci - npm run test - npm run build artifacts: - dist/**
- step: &deploy-step name: Deploy to Capgo script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME
pipelines: branches: main: - step: <<: *build-step - step: <<: *deploy-step name: Deploy to Production deployment: production trigger: manual script: - export CHANNEL_NAME=production - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME
develop: - step: <<: *build-step - step: <<: *deploy-step name: Deploy to Development deployment: development script: - export CHANNEL_NAME=development - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME
pull-requests: '**': - step: <<: *build-step - step: name: Deploy PR to Test Channel script: - CHANNEL_NAME="pr-$BITBUCKET_PR_ID" - npm install -g @capgo/cli - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME artifacts: - dist/**Pianificatore di pipeline multiambiente
Sezione intitolata “Pianificatore di pipeline multiambiente”Per scenari di distribuzione complessi con ambienti di staging e produzione:
# Multi-environment pipelineimage: node:22
pipelines: branches: main: - step: name: Build script: - npm ci - npm run test - npm run build artifacts: - dist/** - step: name: Deploy to Staging deployment: staging script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel staging - step: name: Deploy to Production deployment: production trigger: manual script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production
develop: - step: name: Build and Deploy to Development script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel development artifacts: - dist/**Strategia di distribuzione basata sul ramo
Sezione intitolata “Strategia di distribuzione basata sul ramo”Distribuisce automaticamente rami diversi nei canali appropriati:
# Dynamic channel deploymentimage: node:22
definitions: scripts: - script: &determine-channel | if [ "$BITBUCKET_BRANCH" = "main" ]; then export CHANNEL_NAME="production" elif [ "$BITBUCKET_BRANCH" = "develop" ]; then export CHANNEL_NAME="staging" else export CHANNEL_NAME="development" fi echo "Deploying to channel: $CHANNEL_NAME"
pipelines: default: - step: name: Build and Deploy script: - npm ci - npm run test - npm run build - *determine-channel - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME artifacts: - dist/**Esecuzione parallela di pipeline
Sezione intitolata “Esecuzione parallela di pipeline”Ottimizza i tempi di compilazione con passaggi paralleli:
# Parallel execution pipelineimage: node:22
pipelines: branches: main: - parallel: - step: name: Run Tests script: - npm ci - npm run test - step: name: Lint Code script: - npm ci - npm run lint - step: name: Build Application script: - npm ci - npm run build artifacts: - dist/** - step: name: Deploy to Production deployment: production script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel productionPratiche di sicurezza
Sezione intitolata “Pratiche di sicurezza”Variabili del repository
Sezione intitolata “Variabili del repository”- Variabili protette: Segnala sempre i token API come protetti
- Variabili di ambiente: Utilizza variabili specifiche per la distribuzione quando necessario
- Controllo dell'accesso: Limita l'accesso al repository ai membri del team autorizzati
- Rotazione dei token: Regolare regolarmente i tuoi Capgo API token
Ambienti di distribuzione
Sezione intitolata “Ambienti di distribuzione”Configura gli ambienti di distribuzione per una maggiore sicurezza:
# Deployment with environment restrictionspipelines: branches: main: - step: name: Deploy to Production deployment: production trigger: manual script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel productionMonitoraggio e Notifiche
Sezione intitolata “Monitoraggio e Notifiche”Integrazione con Slack
Sezione intitolata “Integrazione con Slack”Aggiungi notifiche di Slack al tuo pipeline:
# Pipeline with Slack notificationspipelines: branches: main: - step: name: Build and Deploy script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production after-script: - | if [ $BITBUCKET_EXIT_CODE -eq 0 ]; then curl -X POST -H 'Content-type: application/json' \ --data '{"text":"✅ Capgo deployment successful for '$BITBUCKET_BRANCH'"}' \ $SLACK_WEBHOOK_URL else curl -X POST -H 'Content-type: application/json' \ --data '{"text":"❌ Capgo deployment failed for '$BITBUCKET_BRANCH'"}' \ $SLACK_WEBHOOK_URL fiNotifiche via e-mail
Sezione intitolata “Notifiche via Email”Configura le notifiche via email attraverso le funzionalità integrate di Bitbucket o utilizzando servizi esterni:
# Email notification step- step: name: Send Notification script: - | curl -X POST \ -H "Content-Type: application/json" \ -d '{ "to": "team@yourcompany.com", "subject": "Capgo Deployment Status", "body": "Deployment of '$BITBUCKET_BRANCH' completed with status: '$BITBUCKET_EXIT_CODE'" }' \ $EMAIL_SERVICE_URL condition: result: [successful, failed]Risoluzione dei problemi
Sezione intitolata “Risoluzione dei problemi”Problemi comuni
Sezione intitolata “Problemi comuni”Il pipeline fallisce con “Capgo CLI non trovato”:
# Debug CLI installation- step: name: Debug CLI script: - npm install -g @capgo/cli - which capgo || echo "Capgo CLI not found" - npx @capgo/cli --versionErrori di autenticazione:
# Verify token configuration- step: name: Debug Auth script: - | if [ -z "$CAPGO_TOKEN" ]; then echo "CAPGO_TOKEN is not set" exit 1 fi echo "Token length: ${#CAPGO_TOKEN}"Non trovati gli artefatti di costruzione:
# List build outputs- step: name: Debug Build script: - ls -la dist/ - find dist/ -type f -name "*.js" -o -name "*.html"Pianificatore di debug
Sezione intitolata “Pianificatore di debug”Aggiungi informazioni di debug per risolvere problemi:
# Debug pipelinepipelines: branches: main: - step: name: Debug Information script: - echo "Branch: $BITBUCKET_BRANCH" - echo "Commit: $BITBUCKET_COMMIT" - echo "Build: $BITBUCKET_BUILD_NUMBER" - env | grep BITBUCKET_ | sort - step: name: Build and Deploy script: - npm ci - npm run test - npm run build - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel productionValidazione della pipeline
Sezione intitolata “Validazione della pipeline”Abilita la validazione della pipeline per catturare gli errori di configurazione:
# Enable pipeline validationoptions: docker: true size: 2x
pipelines: branches: main: - step: name: Validate Pipeline script: - echo "Pipeline validation successful" - step: name: Build and Deploy script: # ... deployment stepsPassaggi successivi
Sezione intitolata “Passaggi successivi”- Impara su Canali per gestire diversi ambienti di distribuzione
- Esplora Storage personalizzato per scenari di distribuzione avanzati
- Configura Crittografia per distribuzioni sicure
- Configura Comportamento di aggiornamento per personalizzare come vengono applicate le aggiornamenti
Con l'integrazione con Bitbucket Pipelines, puoi automatizzare le tue Capgo distribuzioni e assicurarti aggiornamenti coerenti e affidabili per i tuoi utenti di app mobile.