Intégration CI/CD de GitLab
Copiez une commande de configuration avec les étapes d'installation et la guide markdown complète pour ce plugin.
Intégrez les mises à jour Live avec GitLab CI/CD pour déployer automatiquement les mises à jour de votre application chaque fois que vous publiez des modifications. Cette guide couvre la configuration des workflows de build automatique, de test et de déploiement avec Capgo et code.
Prérequis
Section intitulée « Prérequis »Avant de configurer l'intégration GitLab CI/CD, 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 : Configurer les variables d'environnement
Section intitulée « Étape 1 : Configurer les variables d'environnement »Tout d'abord, configurez 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 vers 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 sur branches de fonctionnalité
Section intitulée « Déploiements de branches de fonctionnalités »Déployez les branches de fonctionnalités 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_NAMESection intitulée « Utilisation de l'encryption »
Si vous utilisez la fonctionnalité d'encryption de__CAPGO_KEEP_0__ Capgo’s encryption feature, vous devrez stocker votre clé privée de manière sécurisée dans votre environnement CI/CD.
Après l'installation des clés d'encryption localement, ajoutez votre clé privée aux variables de GitLab :
# Display your private key content (copy this output)cat .capgo_key_v2Ajoutez ce contenu en tant que CAPGO_PRIVATE_KEY dans les variables de votre projet GitLab (marquez comme protégées et masquées), puis utilisez-les 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 productionSection intitulée « Configuration multi-canal »
Pour obtenir des informations complètes sur la mise en place et la gestion de plusieurs canaux de déploiement, consultez ladocumentation des canaux Configuration complète avec plusieurs environnements et déploiements de demande de fusion :.
Copier dans le presse-papier
# .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: productionSection intitulée « Multi-Environnement avec Approbation Manuelle »
Pour plus d'informations sur la configuration et la gestion de plusieurs canaux de déploiement, voir laPour 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 les branches
Section intitulée “Stratégie de déploiement basée sur les branches”Déployer 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: $CHANNELMeilleures Pratiques de Sécurité
Section intitulée “Meilleures Pratiques de Sécurité”Variables Protégées
Section intitulée “Variables Protégées”- Marquer les variables sensiblesToujours marquer les jetons API comme protégés et masqués
- Protection de branch: Utilisez des variables protégées pour les déploiements de production
- Contrôle d'accès: Limitez l'accès aux variables aux seuls administrateurs
- Rotation régulière: Rotez 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 les paramètres de votre 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: alwaysRésolution des problèmes
Section intitulée « Résolution des problèmes »Problèmes courants
Section intitulée « Problèmes courants »La pipeline a échoué 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”Ajouter 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 savoir plus Canaux pour gérer différents environnements de déploiement
- Explorez Stockage personnalisé pour des scénarios de déploiement avancés
- Configurez Chiffrement pour des déploiements sécurisés
- Configurez Comportement de mise à jour pour personnaliser la façon dont les mises à jour sont appliquées
Avec l'intégration GitLab CI/CD, vous pouvez automatiser vos Capgo déploiements et vous assurer d'une mise à jour cohérente et fiable pour vos utilisateurs de l'application mobile.