Integrazione con GitLab CI/CD
Integra Capgo Live Updates con GitLab CI/CD per distribuire automaticamente gli aggiornamenti della tua app ogni volta che apporti modifiche al codice. Questa guida copre la configurazione di workflow automatizzati di build, test e distribuzione.
Prerequisiti
Section titled “Prerequisiti”Prima di configurare l’integrazione con GitLab CI/CD, assicurati di avere:
- Un account GitLab con un repository di progetto
- Un account Capgo con un’app configurata
- Node.js e npm/yarn configurati nel tuo progetto
Configurazione di GitLab CI/CD
Section titled “Configurazione di GitLab CI/CD”Passaggio 1: Configurare le variabili d’ambiente
Section titled “Passaggio 1: Configurare le variabili d’ambiente”Prima, configura le variabili necessarie nel tuo progetto GitLab:
- Naviga nel tuo progetto GitLab
- Vai su Settings → CI/CD → Variables
- Aggiungi le seguenti variabili:
| Nome Variabile | Valore | Protetta | Mascherata |
|---|---|---|---|
CAPGO_TOKEN | Il tuo token API Capgo | ✅ Sì | ✅ Sì |
Semplice
Section titled “Semplice”Configurazione di base che distribuisce in produzione ad ogni push sul branch main:
# .gitlab-ci.yml - Configurazione sempliceimage: node:22
stages: - build - deploy
variables: npm_config_cache: "$CI_PROJECT_DIR/.npm"
build: stage: build script: - npm ci - npm run test - npm run build artifacts: paths: - dist/ expire_in: 1 hour only: - main
deploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production # Per caricamenti crittografati, aggiungi: --key-data-v2 "$CAPGO_PRIVATE_KEY" dependencies: - build only: - mainAvanzato
Section titled “Avanzato”Distribuzioni dei branch di funzionalità
Section titled “Distribuzioni dei branch di funzionalità”Distribuisci branch di funzionalità su canali di test per revisione e testing:
# Distribuzione dei branch di funzionalitàdeploy_feature: stage: deploy script: - npm install -g @capgo/cli - CHANNEL_NAME="feature-$(echo $CI_COMMIT_REF_NAME | sed 's/[^a-zA-Z0-9-]/-/g')" - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME dependencies: - build only: - /^feature\/.*$/ environment: name: feature/$CI_COMMIT_REF_NAME url: https://your-app.com/channels/$CHANNEL_NAMEUtilizzo della crittografia
Section titled “Utilizzo della crittografia”Se stai utilizzando la funzionalità di crittografia di Capgo, dovrai archiviare la tua chiave privata in modo sicuro nel tuo ambiente CI/CD.
Dopo aver configurato le chiavi di crittografia localmente, aggiungi la tua chiave privata alle variabili di GitLab:
# Visualizza il contenuto della tua chiave privata (copia questo output)cat .capgo_key_v2Aggiungi questo contenuto come CAPGO_PRIVATE_KEY nelle variabili del progetto GitLab (contrassegnala come protetta e mascherata), quindi usala nelle pipeline:
# Distribuzione con crittografiadeploy_production: script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --key-data-v2 "$CAPGO_PRIVATE_KEY" --channel productionConfigurazione multi-canale
Section titled “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 merge request:
# .gitlab-ci.yml - Configurazione avanzata multi-canaleimage: node:22
stages: - build - deploy
variables: npm_config_cache: "$CI_PROJECT_DIR/.npm"
# Fase di buildbuild: stage: build script: - npm ci - npm run test - npm run build artifacts: paths: - dist/ expire_in: 24 hours
# Distribuzione su canale developmentdeploy_development: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel development dependencies: - build only: - develop environment: name: development
# Distribuzione delle merge request su canali di testdeploy_mr: stage: deploy script: - npm install -g @capgo/cli - CHANNEL_NAME="mr-$CI_MERGE_REQUEST_IID" - npx @capgo/cli channel create $CHANNEL_NAME --apikey $CAPGO_TOKEN || true - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL_NAME dependencies: - build only: - merge_requests environment: name: review/$CI_MERGE_REQUEST_IID url: https://your-app.com/channels/mr-$CI_MERGE_REQUEST_IID on_stop: cleanup_mr
# Pulizia dei canali MR quando la MR viene chiusacleanup_mr: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli channel delete mr-$CI_MERGE_REQUEST_IID --apikey $CAPGO_TOKEN || true when: manual environment: name: review/$CI_MERGE_REQUEST_IID action: stop only: - merge_requests
# Distribuzione su stagingdeploy_staging: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel staging dependencies: - build only: - develop environment: name: staging
# Distribuzione su produzionedeploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production dependencies: - build only: - main environment: name: productionMulti-ambiente con approvazione manuale
Section titled “Multi-ambiente con approvazione manuale”Per distribuzioni in produzione che richiedono approvazione manuale:
deploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production dependencies: - build only: - main when: manual environment: name: productionStrategia di distribuzione basata sui branch
Section titled “Strategia di distribuzione basata sui branch”Distribuisci automaticamente branch diversi sui canali appropriati:
# Distribuzione dinamica sui canali in base al branchdeploy: stage: deploy script: - npm install -g @capgo/cli - | if [ "$CI_COMMIT_REF_NAME" = "main" ]; then CHANNEL="production" elif [ "$CI_COMMIT_REF_NAME" = "develop" ]; then CHANNEL="staging" else CHANNEL="development" fi - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel $CHANNEL dependencies: - build environment: name: $CHANNELBest practice di sicurezza
Section titled “Best practice di sicurezza”Variabili protette
Section titled “Variabili protette”- Contrassegna le variabili sensibili: Contrassegna sempre i token API come protetti e mascherati
- Protezione dei branch: Usa variabili protette per le distribuzioni in produzione
- Controllo degli accessi: Limita l’accesso alle variabili solo ai maintainer
- Rotazione regolare: Ruota regolarmente i token API
Configurazione sicura della pipeline
Section titled “Configurazione sicura della pipeline”# Usa variabili protette per la produzionedeploy_production: stage: deploy script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --channel production only: refs: - main variables: - $CI_COMMIT_REF_PROTECTED == "true"Monitoraggio e notifiche
Section titled “Monitoraggio e notifiche”Integrazione con Slack
Section titled “Integrazione con Slack”Aggiungi notifiche Slack alla tua pipeline:
notify_success: stage: .post image: alpine:latest before_script: - apk add --no-cache curl script: - | curl -X POST -H 'Content-type: application/json' \ --data '{"text":"✅ Distribuzione Capgo riuscita per '"$CI_COMMIT_REF_NAME"'"}' \ $SLACK_WEBHOOK_URL when: on_success
notify_failure: stage: .post image: alpine:latest before_script: - apk add --no-cache curl script: - | curl -X POST -H 'Content-type: application/json' \ --data '{"text":"❌ Distribuzione Capgo fallita per '"$CI_COMMIT_REF_NAME"'"}' \ $SLACK_WEBHOOK_URL when: on_failureNotifiche via email
Section titled “Notifiche via email”Configura le notifiche via email nelle impostazioni del progetto GitLab o usa l’API:
notify_email: stage: .post script: - | curl --request POST \ --header "PRIVATE-TOKEN: $GITLAB_API_TOKEN" \ --form "to=team@yourcompany.com" \ --form "subject=Stato distribuzione Capgo" \ --form "body=Distribuzione di $CI_COMMIT_REF_NAME completata con stato: $CI_JOB_STATUS" \ "https://gitlab.com/api/v4/projects/$CI_PROJECT_ID/emails" when: alwaysRisoluzione dei problemi
Section titled “Risoluzione dei problemi”Problemi comuni
Section titled “Problemi comuni”La pipeline fallisce con “Capgo CLI non trovato”:
# Debug installazione CLIdebug_cli: script: - npm install -g @capgo/cli - which capgo || echo "Capgo CLI non trovato" - npx @capgo/cli --versionErrori di autenticazione:
# Verifica configurazione del tokendebug_auth: script: - | if [ -z "$CAPGO_TOKEN" ]; then echo "CAPGO_TOKEN non è impostato" exit 1 fi echo "Lunghezza del token: ${#CAPGO_TOKEN}"Artefatti di build non trovati:
# Elenca gli output di builddebug_build: script: - ls -la dist/ - find dist/ -type f -name "*.js" -o -name "*.html"Debug della pipeline
Section titled “Debug della pipeline”Aggiungi informazioni di debug per risolvere i problemi:
debug: stage: build script: - echo "Branch: $CI_COMMIT_REF_NAME" - echo "Commit: $CI_COMMIT_SHA" - echo "Build: $CI_PIPELINE_ID" - env | grep CI_ | sort only: - branchesProssimi passi
Section titled “Prossimi passi”- Scopri i Canali per gestire diversi ambienti di distribuzione
- Esplora lo Storage personalizzato per scenari di distribuzione avanzati
- Configura la Crittografia per distribuzioni sicure
- Configura il Comportamento degli aggiornamenti per personalizzare come vengono applicati gli aggiornamenti
Con l’integrazione GitLab CI/CD, puoi automatizzare le tue distribuzioni Capgo e garantire aggiornamenti coerenti e affidabili agli utenti della tua app mobile.