Intégration CI/CD de GitLab
Copiez un prompt de configuration avec les étapes d'installation et le guide Markdown complet pour ce plugin.
Intégrez les mises à jour en direct Capgo avec GitLab CI/CD pour déployer automatiquement vos mises à jour d'application chaque fois que vous poussez code des modifications. Ce guide couvre la configuration des workflows de construction automatique, de test et de déploiement.
Prérequis
Section intitulée « Prérequis »Avant de configurer l'intégration CI/CD de GitLab, assurez-vous d'avoir :
- Un compte GitLab avec un référentiel de projet
- Un compte Capgo avec une application configurée
- Node.js et npm/yarn configurés dans votre projet
Configuration de GitLab CI/CD
Section intitulée « Configuration de GitLab CI/CD »Étape 1 : Configurez les variables d'environnement
Section intitulée « Étape 1 : Configurez les variables d'environnement »Configurez d'abord les variables nécessaires dans votre projet GitLab :
- Naviguez vers votre projet GitLab
- Allez à Paramètres → CI/CD → Variables
- Ajoutez les variables suivantes :
| Nom de la variable | Valeur | Protégé | Masqué |
|---|---|---|---|
CAPGO_TOKEN | Votre jeton Capgo API | ✅ Oui | ✅ Oui |
Configuration de base qui déploie en production à chaque push sur la branche principale :
# .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: - mainDéploiements de branche de fonctionnalité
Section intitulée “Déploiements de branche de fonctionnalité”Déploie les branches de fonctionnalité dans les canaux de test pour la revue et les tests :
# 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_NAMEUtilisation de l'encryption
Section intitulée “Utilisation de l'encryption”Si vous utilisez Capgo’s fonctionnalité d'encryption, vous devrez stocker votre clé privée de manière sécurisée dans votre environnement CI/CD.
Après la mise en place des clés d'encryption locale, ajoutez votre clé privée aux variables de GitLab:
# Display your private key content (copy this output)cat .capgo_key_v2Ajoutez ce contenu comme CAPGO_PRIVATE_KEY dans les variables de votre projet GitLab (marquez-le comme protégé et masqué), puis utilisez-le dans les 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 productionConfiguration multimédia
Sous-section intitulée « Configuration multimédia »Pour obtenir des informations complètes sur la configuration et la gestion de plusieurs canaux de déploiement, consultez la documentation des canaux.
Configuration complète avec plusieurs environnements et déploiements de demande de fusion :
# .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: productionDéploiement multi-environnement avec approbation manuelle
Section intitulée “Déploiement multi-environnement avec approbation manuelle”Pour les déploiements de production nécessitant une approbation manuelle :
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: productionStratégie de déploiement basée sur la branch
Section intitulée “Stratégie de déploiement basée sur la branch”Déployez différentes branches dans les canaux appropriés automatiquement :
# 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: $CHANNELPratiques de Sécurité
Section intitulée « Pratiques de Sécurité »Variables Protégées
Section intitulée « Variables Protégées »- Marquer les Variables Sensibles: Toujours marquer les jetons API comme protégés et masqués
- Protection de Branches: Utiliser les variables protégées pour les déploiements de production
- Contrôle d'Accès: Limiter l'accès aux variables pour mainteneurs seulement
- Rotation Régulière: Roter les jetons API régulièrement
Configuration de pipeline sécurisée
Section intitulée « Configuration de pipeline sécurisée »# 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"Surveillance et notifications
Section intitulée « Surveillance et notifications »Intégration Slack
Section intitulée « Intégration Slack »Ajoutez des notifications Slack à votre 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":"✅ 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_failureNotifications par e-mail
Section intitulée « Notifications par e-mail »Configurez les notifications par e-mail dans vos paramètres de projet GitLab ou utilisez le API:
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: alwaysDépannage
Section intitulée « Dépannage »Problèmes courants
Section intitulée « Problèmes courants »La pipeline échoue avec « Capgo CLI non trouvé » :
# Debug CLI installationdebug_cli: script: - npm install -g @capgo/cli - which capgo || echo "Capgo CLI not found" - npx @capgo/cli --versionErreurs d'authentification :
# Verify token configurationdebug_auth: script: - | if [ -z "$CAPGO_TOKEN" ]; then echo "CAPGO_TOKEN is not set" exit 1 fi echo "Token length: ${#CAPGO_TOKEN}"Artéfacts de construction non trouvés :
# List build outputsdebug_build: script: - ls -la dist/ - find dist/ -type f -name "*.js" -o -name "*.html"Pipeline de débogage
Section intitulée « Pipeline de débogage »Ajoutez des informations de débogage pour résoudre les problèmes :
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: - branchesÉtapes suivantes
Section intitulée « Étapes suivantes »- En apprendre plus sur Canaux pour gérer différents environnements de déploiement
- Explorer Stockage personnalisé pour des scénarios de déploiement avancés
- Configurer Chiffrement pour des déploiements sécurisés
- Configurer Mise à jour du comportement pour personnaliser la façon dont les mises à jour sont appliquées
Avec l'intégration GitLab CI/CD, vous pouvez automatiser vos déploiements Capgo et vous assurer d'une mise à jour cohérente et fiable pour vos utilisateurs d'applications mobiles.
Continuez de GitLab CI/CD Integration
Titre de la section « Continuez de GitLab CI/CD Integration »Si vous utilisez L'intégration CI/CD GitLab pour planifier l'automatisation CI/CD, connectez-la avec Capgo CI/CD pour le flux de produit dans Capgo CI/CD, Capgo Builds natifs pour le flux de produit dans Capgo Builds natifs, Capgo Intégrations pour le flux de produit dans Capgo Intégrations, Intégration CI/CD pour le détail d'implémentation dans Intégration CI/CD, et GitHub Intégration d'actions pour le détail d'implémentation dans GitHub Intégration d'actions.