GitLab CI/CD-Integration
Eine Einrichtungsvorschlag mit den Installationsanweisungen und der vollständigen Markdown-Guideline für diesen Plugin kopieren.
Integriere Capgo Live Updates mit GitLab CI/CD, um Ihre App-Updates automatisch zu deployen, sobald Sie code Änderungen pushen. Dieser Leitfaden behandelt die Einrichtung automatischer Builds, Tests und Bereitstellungsdienste.
Voraussetzungen
Abschnitt mit dem Titel „Voraussetzungen“Bevor Sie die GitLab CI/CD-Integration einrichten, stellen Sie sicher, dass Sie haben:
- Ein GitLab-Konto mit einem Projekt-Repository
- Ein Capgo-Konto mit einer konfigurierten App
- Node.js und npm/yarn in Ihrem Projekt konfiguriert
Einrichtung von GitLab CI/CD
Abschnitt mit dem Titel „GitLab CI/CD einrichten“Schritt 1: Umgebungsvariablen konfigurieren
Abschnitt mit dem Titel „Schritt 1: Umgebungsvariablen konfigurieren“Zunächst müssen Sie in Ihrem GitLab-Projekt die notwendigen Variablen einrichten:
- Navigieren Sie zu Ihrem GitLab-Projekt
- Zum Einstellungen → CI/CD → Variablen
- Fügen Sie die folgenden Variablen hinzu:
| Variablenname | Wert | Geschützt | Maskiert |
|---|---|---|---|
CAPGO_TOKEN | Ihr Capgo API Token | ✅ Ja | ✅ Ja |
Einfach
EinfachGrundlegende Konfiguration, die auf jeden Push in die Hauptzweig in die Produktion deployt:
# .gitlab-ci.yml - Simple Configurationimage: 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 # For encrypted uploads, add: --key-data-v2 "$CAPGO_PRIVATE_KEY" dependencies: - build only: - mainErweitert
EinfachFeature-Zweig-Deployments
EinfachFeature-Zweige in Testkanäle für Überprüfung und Testen deployen:
# Feature branch deploymentdeploy_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_NAMEVerwendung der Verschlüsselung
Abschnitt mit dem Titel „Verwendung der Verschlüsselung“Wenn Sie die Capgo-Verschlüsselungsfunktion verwenden, müssen Sie Ihren privaten Schlüssel sicher in Ihrem CI/CD-Umgebung speichern.
Nachdem Sie die Verschlüsselungsschlüssel lokale Fügen Sie Ihren privaten Schlüssel zu den GitLab-Variablen hinzu:
# Display your private key content (copy this output)cat .capgo_key_v2Fügen Sie diesen Inhalt als CAPGO_PRIVATE_KEY im Variablenbereich Ihres GitLab-Projekts (als geschützt und maskiert markieren) ein, dann verwenden Sie es in Pipelines:
# Deploy with encryptiondeploy_production: script: - npm install -g @capgo/cli - npx @capgo/cli bundle upload --apikey $CAPGO_TOKEN --key-data-v2 "$CAPGO_PRIVATE_KEY" --channel productionMulti-Channel-Konfiguration
Abschnitt mit dem Titel „Multi-Channel-Konfiguration“Für umfassende Informationen zur Einrichtung und Verwaltung mehrerer Bereitstellungskanäle, siehe die __CAPGO_KEEP_0__.
Vollständige Konfiguration mit mehreren Umgebungen und Merge-Anforderungs-Bereitstellungen:
# .gitlab-ci.yml - Advanced Multi-Channel Configurationimage: node:22
stages: - build - deploy
variables: npm_config_cache: "$CI_PROJECT_DIR/.npm"
# Build stagebuild: stage: build script: - npm ci - npm run test - npm run build artifacts: paths: - dist/ expire_in: 24 hours
# Deploy to development channeldeploy_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
# Deploy merge requests to test channelsdeploy_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
# Cleanup MR channels when MR is closedcleanup_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
# Deploy to 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
# Deploy to productiondeploy_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-Umgebung mit manuellem Genehmigungsverfahren
__CAPGO_KEEP_1__Für Produktionsbereitstellungen, die eine manuelle Genehmigung erfordern:
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: productionBranchen-basierte Bereitstellungstrategie
__CAPGO_KEEP_2__Bereitstellen Sie verschiedene Branchen automatisch auf geeignete Kanäle:
# Dynamic channel deployment based on 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: $CHANNELSicherheitsbest Practices
Abschnitt mit dem Titel „Sicherheitsbest Practices”Geschützte Variablen
Abschnitt mit dem Titel „Geschützte Variablen”- Markiere sensitive Variablen: Markiere API-Token immer als geschützt und maskiert
- Zweigschutz: Verwende geschützte Variablen für Produktionsdeployments
- Zugriffssteuerung: Beschränke den Zugriff auf Variablen auf Maintainer
- Regelmäßige Rotation: Rotiere API-Token regelmäßig
Sichere Pipeline-Konfiguration
Abschnitt mit dem Titel „Sichere Pipeline-Konfiguration“# Use protected variables for productiondeploy_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"Überwachung und Benachrichtigungen
Abschnitt mit dem Titel „Überwachung und Benachrichtigungen“Slack-Integration
Abschnitt mit dem Titel „Slack-Integration“Slack-Benachrichtigungen zu Ihrer Pipeline hinzufügen:
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":"✅ Capgo deployment successful for '"$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":"❌ Capgo deployment failed for '"$CI_COMMIT_REF_NAME"'"}' \ $SLACK_WEBHOOK_URL when: on_failureE-Mail-Benachrichtigungen
Abschnitt mit dem Titel „E-Mail-Benachrichtigungen“E-Mail-Benachrichtigungen in Ihren GitLab-Projekt-Einstellungen konfigurieren oder den API: verwenden
notify_email: stage: .post script: - | curl --request POST \ --header "PRIVATE-TOKEN: $GITLAB_API_TOKEN" \ --form "to=team@yourcompany.com" \ --form "subject=Capgo Deployment Status" \ --form "body=Deployment of $CI_COMMIT_REF_NAME completed with status: $CI_JOB_STATUS" \ "https://gitlab.com/api/v4/projects/$CI_PROJECT_ID/emails" when: alwaysFehlersuche
Abschnitt mit dem Titel “Fehlersuche”Häufige Probleme
Abschnitt mit dem Titel “Häufige Probleme”Pipeline fehlt mit “Capgo CLI nicht gefunden”:
# Debug CLI installationdebug_cli: script: - npm install -g @capgo/cli - which capgo || echo "Capgo CLI not found" - npx @capgo/cli --versionAuthentifizierungsfehler:
# Verify token configurationdebug_auth: script: - | if [ -z "$CAPGO_TOKEN" ]; then echo "CAPGO_TOKEN is not set" exit 1 fi echo "Token length: ${#CAPGO_TOKEN}"Build-Artikel nicht gefunden:
# List build outputsdebug_build: script: - ls -la dist/ - find dist/ -type f -name "*.js" -o -name "*.html"Debug-Pipeline
Abschnitt mit dem Titel “Fehlerrückverfolgungspipeline”Fügen Sie Fehlerbehebungsinformationen hinzu, um Probleme zu lösen:
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: - branchesNächste Schritte
Abschnitt mit dem Titel “Nächste Schritte”- Erfahren Sie mehr über Kanäle um verschiedene Bereitstellungsumgebungen zu verwalten
- Erkunden Sie Benutzerdefinierte Speicherung für fortgeschrittene Bereitstellungsanforderungen
- Einrichten Verschlüsselung für sichere Bereitstellungen
- Konfigurieren Aktualisierungsverhalten anpassen um zu bestimmen, wie Aktualisierungen angewendet werden
Mit der Integration von GitLab CI/CD können Sie Ihre Capgo-Bereitstellungen automatisieren und sicherstellen, dass Ihre mobilen App-Benutzer konsistente und zuverlässige Aktualisierungen erhalten.
Weitermachen von GitLab CI/CD-Integration
Abschnitt mit dem Titel “Weitermachen von GitLab CI/CD-Integration”Wenn Sie GitLab CI/CD-Integration verwenden um die CI/CD-Automatisierung zu planen, verbinden Sie sie mit __CAPGO_KEEP_0__ CI/CD Capgo CI/CD für den Produktworkflow in Capgo CI/CD, Capgo Native Builds für den Produktworkflow in Capgo Native Builds, Capgo Integrations für den Produktworkflow in Capgo Integrations, CI/CD-Integration für die Implementierungsdetails in CI/CD-Integration, und GitHub Actions-Integration für die Implementierungsdetails in GitHub Actions-Integration.