Aller directement au contenu principal

Comment personnaliser les scripts de construction avec Capacitor CLI

Découvrez comment personnaliser vos scripts de construction à l'aide de Capacitor CLI pour des déploiements efficaces et des mises à jour d'applications personnalisées sur plusieurs plateformes.

Martin Donadieu

Martin Donadieu

Spécialiste du contenu

Comment personnaliser les scripts de construction avec Capacitor CLI

Capacitor CLI vous permet de personnaliser le processus de construction de votre application pour les plateformes iOS, Android et web. En ajustant les scripts de construction, vous pouvez :

  • Accélérez les mises à jour: Envoyez des modifications instantanément sans retard des magasins d'applications.
  • Contrôlez les déploiements: Annulez les mises à jour ou ciblez des groupes d'utilisateurs spécifiques.
  • Sécurisez votre application: Utilisez l'encryption pour protéger les mises à jour.
  • Résumé rapide des fonctionnalités clés :Fichiers de configuration

: Utilisez __CAPGO_KEEP_0__

  • etOptimisez les builds capacitor.config.json : Ajustez les paramètres pour les besoins spécifiques des plateformes. package.json gérer les paramètres de construction.
  • Scripts personnalisés: Ajouter des tâches pré et post-construction pour l'automatisation.
  • Hooks de construction: Exécuter code lors de certaines étapes du processus de construction.
  • Variables d'environnement: Simplifier les constructions spécifiques à l'environnement avec .env fichiers.

Capgo, un outil de déploiement, améliore ce processus avec mises à jour automatiques, suivi de version, et optimisation de performances globale. Lisez-en davantage pour apprendre à configurer et personnaliser vos scripts de construction pour une efficacité maximale.

Présentation Capacitor Configurer

Capacitor Documentation du Framework

Processus de construction par défaut dans Capacitor

Comprendre comment Capacitor gère son processus de construction par défaut est crucial si vous souhaitez le personnaliser efficacement. En dessous, nous allons décomposer le processus de construction de Capacitor CLI et ses fichiers de configuration clés.

Étapes de construction standard

Capacitor utilise un processus étape par étape pour transformer votre application web en builds spécifiques au plateau. Voici ce qui se passe pendant le processus de construction par défaut :

PhaseDescriptionSortie
Build WebCompile des actifs web en utilisant vos outils de frameworkBundle web optimisé
Copier les actifsDéplace les actifs web vers les dossiers de plateforme nativeRépertoires d'actifs spécifiques à la plateforme
Build NativeExécute les commandes de build spécifiques à la plateformeBinaires prêts à la mise en production
VérificationVérifie l'intégrité et les dépendances de la buildStatut et avertissements de la build

Fichiers de configuration principaux

Two key configuration files shape how Capacitor handles your builds:

capacitor.config.json
This is the core configuration file for your Capacitor project. It sets important parameters for your builds:

{
  "appId": "com.example.app",
  "appName": "MyApp",
  "webDir": "dist",
  "bundledWebRuntime": false,
  "plugins": {
    "SplashScreen": {
      "launchShowDuration": 3000
    }
  }
}
  • appId: Un identifiant unique pour votre application.
  • appName: Le nom de votre application.
  • webDir: Specifies where Capacitor should look for the web assets (e.g., dist).
  • plugins: Permet de configurer les paramètres spécifiques des plugins, comme les options de SplashScreen.

package.json
Ce fichier inclut des scripts de construction et des dépendances qui influencent le processus de construction :

{
  "scripts": {
    "build": "npm run build:web && cap sync",
    "build:web": "vite build",
    "cap:build": "cap build"
  }
}
  • Le webDir paramètre capacitor.config.json indique à Capacitor où localiser vos actifs web compilés pour les inclure dans les builds natifs.
  • Après avoir apporté des modifications à capacitor.config.json, vous devez exécuter cap sync pour vous assurer que vos projets natifs sont mis à jour.

Nous allons ensuite explorer comment vous pouvez modifier ces paramètres pour personnaliser encore plus vos builds.

Paramètres de Script de Build

Vous pouvez adapter le processus de build par défaut de Capacitor pour mieux répondre aux besoins de votre projet. Voici comment faire :

Paramètres du Fichier de Configuration

Vous pouvez ajuster le processus de build en éditant le capacitor.config.json fichier. Voici un exemple de configuration :

{
  "appId": "com.example.app",
  "webDir": "www",
  "server": {
    "hostname": "localhost",
    "androidScheme": "https",
    "iosScheme": "https",
    "allowNavigation": ["*.example.com"]
  },
  "android": {
    "buildOptions": {
      "keystorePath": "release.keystore",
      "keystorePassword": "mypassword",
      "keystoreAlias": "release",
      "keystoreAliasPassword": "mypassword"
    }
  },
  "ios": {
    "scheme": "App",
    "automaticProvisioning": true
  }
}

Voici quelques paramètres clés que vous pouvez modifier :

  • webDir: Spécifie où se trouvent vos actifs web compilés.
  • server: Configure le serveur de développement, y compris l'hôte et les autorisations de navigation.
  • android/ios: Permet des paramètres de construction spécifiques à la plateforme, comme les détails de la clé de stockage pour Android ou les options de provisionnement pour iOS.

Création de Scripts NPM

Pour simplifier votre flux de travail, ajoutez des scripts NPM personnalisés à votre package.json fichier. Voici un exemple :

{
  "scripts": {
    "prebuild": "node ./scripts/prepare-env.js",
    "build": "npm run build:web && cap sync",
    "build:web": "vite build",
    "build:ios": "cap build ios --release",
    "build:android": "cap build android --release",
    "postbuild": "node ./scripts/notify-completion.js"
  }
}
  • prebuild et postbuild: Utilisez-les pour des tâches comme la configuration de l'environnement ou l'envoi de notifications lorsque la construction est terminée.
  • build:platform: Commandes spécifiques à la plateforme pour la construction d'applications Android ou iOS.

Vous pouvez prendre l'automatisation encore plus loin en ajoutant des appels de construction.

Configuration des Appels de Construction

Pour un contrôle plus avancé, utilisez les appels de construction pour exécuter des code personnalisés à des points spécifiques du processus de construction. Voici un exemple de configuration dans capacitor.config.ts:

import { CapacitorConfig } from '@capacitor/cli';

const config: CapacitorConfig = {
  appId: 'com.example.app',
  plugins: {
    CapacitorHooks: {
      beforeBuild: async () => {
        console.log('Running pre-build tasks...');
        // Add your pre-build tasks here
      },
      afterBuild: async () => {
        console.log('Running post-build tasks...');
        // Add your post-build tasks here
      }
    }
  }
};

export default config;

Avec les appels de construction, vous pouvez :

  • Vérifiez les exigences avant le démarrage de la construction
  • Transformez les actifs pendant le processus
  • Déclenchez des notifications aux points clés
  • Mettez à jour les numéros de version automatiquement
  • Exécutez des tests automatisés sans heurts

Cette approche vous offre une plus grande flexibilité et contrôle sur l'ensemble du cycle de construction.

Personnalisation de la construction avancée

Lorsque vous travaillez sur des projets plus importants, la fine-tuning de votre processus de construction peut faire une grande différence. Voici comment gérer les constructions spécifiques à l'environnement et les personnalisations de plateforme de manière efficace.

Variables d'environnement

Configurez les variables d'environnement en créant des fichiers séparés pour chaque environnement : .env Ensuite, configurez votre script de construction pour charger le fichier approprié en fonction de l'environnement :

  • .env.development
  • .env.staging
  • .env.production

Set up environment variables by creating separate files for each environment: __CAPGO_KEEP_0__

import { defineConfig } from '@capacitor/cli';

export default defineConfig({
  ios: {
    buildConfig: {
      environment: process.env.BUILD_ENV || 'development',
      configurations: {
        development: {
          signing: {
            debug: true,
            automaticProvisioning: true
          }
        },
        production: {
          signing: {
            release: true,
            provisioningProfile: 'dist/profile.mobileprovision'
          }
        }
      }
    }
  }
});

Vous pouvez encore ajuster ces paramètres pour les adapter aux exigences spécifiques de la plateforme.

Constructions de Plateforme

Pour personnaliser les constructions pour Android et iOS, utilisez la structure suivante :

const platformConfig = {
  android: {
    buildType: process.env.BUILD_TYPE || 'debug',
    keystoreConfig: {
      path: process.env.KEYSTORE_PATH,
      password: process.env.KEYSTORE_PASSWORD,
      alias: process.env.KEYSTORE_ALIAS
    }
  },
  ios: {
    scheme: process.env.APP_SCHEME || 'App',
    xcodePreferences: {
      automaticSigning: false,
      developmentTeam: process.env.DEVELOPMENT_TEAM
    }
  }
};

Ces configurations vous permettent de personnaliser les constructions pour chaque plateforme, garantissant des déploiements plus fluides.

FonctionnalitéAndroidiOS
Symboles de DébogageProGuard fichiers de cartographiefichiers dSYM
Variantes de Constructiondebug, release, préproductiondebug, release
Code SignatureGestion des clés de signatureGestion des profils de provisionnement
Gestion des actifsOptimisation de res/drawableCatalogues d'actifs

D'autres conseils pour optimiser vos builds incluent :

  • Utilisation de mises à jour partielles pour économiser du temps lors des déploiements
  • Configuration de la traçabilité des erreurs pour identifier rapidement les problèmes
  • Création de systèmes de canaux pour les versions de test en bêta
  • Activation de la cryptage de bout en bout pour une distribution sécurisée

Lorsqu'il est associé à des outils comme Capgo pour les analyses et les mises à jour sécurisées, ces techniques vous donnent plus de contrôle sur votre processus de déploiement [1].

Problèmes de script de construction & corrections

Lorsque vous travaillez avec des configurations de construction personnalisées, résoudre rapidement les erreurs est crucial pour maintenir le processus de construction en cours

Correction des erreurs courantes

De nombreux problèmes de script de construction proviennent de la configuration de l'environnement ou de problèmes de dépendances. Voici comment aborder certaines des plus courantes :

Variables d'environnement manquantes

Si vous rencontrez une erreur comme celle-ci :

error: Cannot find environment configuration for BUILD_ENV

Vous pouvez la corriger en créant un .env.local fichier dans le répertoire racine de votre projet. Voici un exemple :

BUILD_ENV=development
CAPACITOR_PLATFORM=ios
BUILD_TYPE=debug

Échecs de construction spécifiques à la plateforme

Pour les erreurs de signature Android, utilisez cette commande :

npx cap build android --keystorePassword=$KEYSTORE_PASSWORD --keystoreAlias=$KEYSTORE_ALIAS

Pour les problèmes de profil de provisionnement iOS, essayez ceci :

npx cap build ios --configuration=release --type=development
Type d'erreurCause communeSolution
Configuration de signatureDétails de clé de magasin manquantsDéfinir KEYSTORE_PATH et les informations d'identification
Environnement de constructionVariables non définiesCréer des fichiers spécifiques à la plateforme .env Fichier de configuration
DépendancesIncompatibilités de versionMettre à jour package.json et synchroniser

Après avoir appliqué les corrections, assurez-vous que vos modifications sont solides en exécutant des tests de construction approfondis.

Tester les scripts de construction

Une fois les erreurs résolues, validez vos scripts de construction avec ces étapes :

  • Vérification automatique: Exécutez des commandes clés pour confirmer que le processus de construction fonctionne comme prévu.
npm run build
npx cap sync
npx cap copy
  • Validation de l'environnement: Vérifiez les variables d'environnement manquantes avant de démarrer la construction.
const requiredVars = ['BUILD_ENV', 'KEYSTORE_PATH'];
requiredVars.forEach(varName => {
  if (!process.env[varName]) {
    throw new Error(`Missing required env var: ${varName}`);
  }
});
  • Débogage des scripts de construction: Ajoutez des scripts détaillés pour détecter les problèmes potentiels lors de la construction.
{
  "scripts": {
    "build:debug": "NODE_ENV=development npx cap build --verbose",
    "build:release": "NODE_ENV=production npx cap build --verbose"
  }
}

Conseils supplémentaires pour la mise en œuvre de tests :

  • Utilisez Docker les conteneurs pour isoler les constructions.
  • Vérifiez les fichiers de configuration avant de démarrer le processus.
  • Testez avec plusieurs versions de Node.js. Confirmez que les exigences spécifiques au système d'exploitation sont remplies.
  • Surveillez la performance de la construction pour des améliorations possibles.
  • __CAPGO_KEEP_0__

Capgo Construire des fonctionnalités

Capgo Mise à jour en direct du tableau de bord de l'interface

Capgo améliore les scripts de construction en automatisant la mise en ligne, ce qui accélère l'efficacité et simplifie le processus.

Mises à jour rapides des applications

Capgo offre une performance de mise à jour impressionnante :

  • 95 % des utilisateurs actifs reçoivent des mises à jour dans les 24 heures. Taux de réussite de 82 %
  • pour la livraison de mises à jour à l'échelle mondiale. Une réponse moyenne de __CAPGO_KEEP_0__ de 434 ms à l'échelle mondiale
  • An average API response time of Mise à jour rapide des applications.

La plateforme utilise des mises à jour partielles, ce qui signifie que seuls les changements sont téléchargés. Cette approche réduit l'utilisation de la bande passante et accélère le processus de mise à jour.

Automatisation de Build

Capgo fonctionne de manière fluide avec les principaux plateformes CI/CD, proposant une variété d'intégrations :

Plateforme CI/CDFonctionnalités d'intégrationAvantages
GitHub ActionsDéploiements automatiques, Déclencheurs de déploiementDéploiement continu
GitLab CIAutomatisation de pipeline, Contrôle de versionFlux de travail simplifié
JenkinsFlux de travail personnalisés, Lancer des hooksÉchelle pour les entreprises

La mise en place d'une construction automatisée coûte généralement autour de $300 par moisce qui est beaucoup plus abordable par rapport aux solutions traditionnelles qui peuvent aller jusqu'à $6,000 par an.

Normes de sécurité

Capgo donne la priorité à la sécurité avec un cadre robuste qui comprend :

  • Chiffrement de bout en bout pour les packages de mise à jour.
  • Gestion des clés sécurisée.
  • Conformité aux lignes directrices d'Apple et de Google.

Fonctionnalités de contrôle de version

  • Options de roulage instantanés.
  • Suivi de la version de déploiement.
  • Gestion du canal d'actualisation pour les lancements étalés.

Ce cadre de sécurité a été rigoureusement testé sur des centaines d'applications d'entreprise. Pour les équipes ayant besoin d'une sécurité supplémentaire, Capgo propose également des solutions auto-hébergées avec des configurations personnalisables.

Capgo’s système de canaux rend la distribution d’actualisations flexible. Les développeurs peuvent cibler des groupes d’utilisateurs spécifiques avec différentes versions, parfait pour les tests de beta ou les lancements progressifs.

Résumé

Vue d'ensemble des étapes de construction

Les scripts de construction personnalisés permettent des déploiements automatisés et cohérents en exploitant les appels de fonctions de construction, les variables d'environnement et les commandes spécifiques au plateau. Ces processus créent une base solide pour les améliorations de déploiement rendues possibles avec Capgo.

Avantages de Capgo

Capgo simplifie le déploiement, ayant réussi à livrer plus de 23,5 millions d'actualisations sur 750 applications de production. [1]Son système d'actualisation partielle réduit à la fois la consommation de bande passante et le temps de déploiement.

La plateforme fournit des mises à jour rapides, une optimisation de performances mondiale, une encryption de bout-en-bout pour la sécurité, et un système de distribution basé sur des canaux flexible. Cette configuration prend en charge les mises à jour ciblées, les tests de beta et le respect des lignes directrices des magasins d'applications tout en maintenant un cadre de sécurité solide.

Mises à jour en temps réel pour les applications Capacitor

Lorsqu'un bug de la couche web est en ligne, expédiez la correction à travers Capgo au lieu d'attendre des jours pour l'approbation de la boutique d'applications. Les utilisateurs reçoivent la mise à jour en arrière-plan tandis que les modifications natives restent dans le chemin de revue normal.

Commencez maintenant

Dernières actualités de notre blog

Capgo vous donne les meilleures informations dont vous avez besoin pour créer une application mobile vraiment professionnelle.