Aller directement à la navigation

Ciblage de Version

Cette guide explique comment livrer automatiquement le bundle compatible le plus récent aux utilisateurs en fonction de leur version d'appareil native. similaire à l'approche d'AppFlow d'Ionic. Cela garantit une mise à jour simplifiée et des déploiements plus rapides tout en prévenant les problèmes de compatibilité.

Capgo's système de ciblage de version permet de :

  • Déployer automatiquement des mises à jour compatibles aux utilisateurs en fonction de leur version d'appareil native
  • Prévenir les modifications de rupture de parvenir aux versions d'applications incompatibles
  • Gérer plusieurs versions d'applications simultanément sans logique complexe
  • Lancer les mises à jour de manière fluide vers des segments d'utilisateurs spécifiques

Pourquoi la ciblage de version est important (Surtout pour les utilisateurs d'AppFlow)

Pourquoi le ciblage de version est important (Surtout pour les utilisateurs d'AppFlow)

Si vous êtes familiarisé avec Ionic AppFlowvous savez à quel point il est crucial de s'assurer que les utilisateurs reçoivent uniquement des mises à jour compatibles. AppFlow a automatiquement associé des lots de mise à jour en direct aux versions natives d'applications, empêchant ainsi que du JavaScript incompatibles ne soit pas livré aux versions natives code plus anciennes.

Capgo fournit les mêmes garanties de sécuritéavec des fonctionnalités supplémentaires :

  • Un contrôle plus granulaire sur la correspondance de version
  • Plusieurs stratégies (canaux, semver, contraintes natives)
  • Une meilleure visibilité sur la distribution des versions
  • API et CLI contrôlent aux côtés de la gestion du tableau de bord

Cette approche est particulièrement utile lorsque :

  • Vous avez des utilisateurs sur différentes versions majeures de votre application (par exemple, v1.x, v2.x, v3.x)
  • Vous avez besoin de maintenir la compatibilité inverse tandis que vous mettez en place des changements brisants
  • Vous voulez empêcher les nouvelles archives de casser les anciens natives code
  • Vous êtes en train de migrer les utilisateurs progressivement d'une version à l'autre
  • Vous êtes en train de migrer de AppFlow et vous voulez maintenir la même sécurité de mise à jour

Capgo utilise une approche multi-niveaux pour correspondre les utilisateurs avec des mises à jour compatibles :

  1. Contraintes de version native: Empêcher les bundles d'être livrés à des versions natives incompatibles
  2. Routage basé sur les canaux: Diriger différentes versions d'applications vers différents canaux de mise à jour
  3. Contrôles de version sémantique: Bloquer automatiquement les mises à jour à travers les limites majeures/minores/patch
  4. Survol des appareils: Cibler des appareils spécifiques ou des groupes d'utilisateurs

Flux de correspondance de version

Flux de correspondance de version
graph TD
A[User Opens App] --> B{Check Device Override}
B -->|Override Set| C[Use Override Channel]
B -->|No Override| D{Check local plugin channel}
D -->|setChannel value| E[Use local setChannel channel]
D -->|No local channel| F{Check defaultChannel in App}
F -->|Has defaultChannel| G[Use App's defaultChannel]
F -->|No defaultChannel| H[Use Cloud Default Channel]
C --> I{Check Version Constraints}
E --> I
G --> I
H --> I
I -->|Compatible| J[Deliver Update]
I -->|Incompatible| K[Skip Update]

Stratégie 1 : Routage de version basé sur le canal

Section intitulée « Stratégie 1 : Routage de version basé sur le canal »

Ceci est l’approche recommandée pour gérer les changements majeurs et les mises à jour de version majeure. C’est similaire au modèle de livraison d’AppFlow.

  • App v1.x (100 000 utilisateurs) → production canal
  • App v2.x (50 000 utilisateurs avec des modifications de rupture) → v2 canal
  • App v3.x (10 000 utilisateurs bêta) → v3 canal

Étape 1 : Configurer les canaux pour chaque version majeure

Section intitulée “Étape 1 : Configurer les canaux pour chaque version majeure”
// capacitor.config.ts for version 1.x builds
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.example.app',
appName: 'Example App',
plugins: {
CapacitorUpdater: {
autoUpdate: 'atBackground',
defaultChannel: 'production', // or omit for default
}
}
};
export default config;
// capacitor.config.ts for version 2.x builds
const config: CapacitorConfig = {
appId: 'com.example.app',
appName: 'Example App',
plugins: {
CapacitorUpdater: {
autoUpdate: 'atBackground',
defaultChannel: 'v2', // Routes v2 users automatically
}
}
};
// capacitor.config.ts for version 3.x builds
const config: CapacitorConfig = {
appId: 'com.example.app',
appName: 'Example App',
plugins: {
CapacitorUpdater: {
autoUpdate: 'atBackground',
defaultChannel: 'v3', // Routes v3 users automatically
}
}
};
Fenêtre de terminal
# Create channels for each major version
npx @capgo/cli channel create production
npx @capgo/cli channel create v2
npx @capgo/cli channel create v3
# Enable self-assignment so apps can switch channels
npx @capgo/cli channel set production --self-assign
npx @capgo/cli channel set v2 --self-assign
npx @capgo/cli channel set v3 --self-assign

Étape 3 : Télécharger des ensembles de versions spécifiques

Section intitulée “Étape 3 : Télécharger des ensembles de versions spécifiques”
Fenêtre de terminal
# For v1.x users (from v1-maintenance branch)
git checkout v1-maintenance
npm run build
npx @capgo/cli bundle upload --channel production
# For v2.x users (from v2-maintenance or main branch)
git checkout main
npm run build
npx @capgo/cli bundle upload --channel v2
# For v3.x users (from beta/v3 branch)
git checkout beta
npm run build
npx @capgo/cli bundle upload --channel v3
  • Aucune modification code - La routage de canal se produit automatiquement
  • Séparation claire - Chaque version a son propre pipeline d'actualisation
  • Ciblage flexible - Mettre à jour spécifiquement les groupes de versions
  • Déploiements sûrs - Les modifications de rupture ne parviennent jamais aux versions incompatibles

Utilisez les contrôles de versionnement sémantique intégrés de Capgo pour empêcher les mises à jour à travers les limites de version. Désactiver la mise à jour automatique entre les versions majeures

Section intitulée « Désactiver la mise à jour automatique entre les versions majeures »

Fenêtre de terminal
Copier dans le presse-papier
# Create a channel that blocks major version updates
npx @capgo/cli channel create stable --disable-auto-update major

Les utilisateurs sur la version de l'application

  • recevront des mises à jour jusqu'à 1.2.3 Les utilisateurs recevront 1.9.9
  • Users will Ne pas recevoir la version 2.0.0 automatiquement
  • Empêche les modifications de rupture d'atteindre les code natives plus anciennes
  • La comparaison utilise la ligne de base native envoyée comme version_build
Fenêtre de terminal
# Block target bundles outside the native major.minor line (1.2.x won't get 1.3.0)
npx @capgo/cli channel set stable --disable-auto-update minor
# Block target bundles outside the exact native MAJOR.MINOR.PATCH core (1.2.3 won't get 1.2.4)
npx @capgo/cli channel set stable --disable-auto-update patch
# Allow all updates
npx @capgo/cli channel set stable --disable-auto-update none

Définir les exigences minimales de version native pour les lots pour empêcher la livraison à des appareils incompatibles.

Utilisation de la condition de retard de version native

Section intitulée « Utilisation de la condition de retard de version native »

Lors de l'upload d'un lot, vous pouvez spécifier une version native minimale :

Fenêtre de terminal
# This bundle requires native version 2.0.0 or higher
npx @capgo/cli bundle upload \
--channel production \
--native-version "2.0.0"
  1. Nouveau plugin natif requis

    Fenêtre de terminal
    # Bundle needs Camera plugin added in v2.0.0
    npx @capgo/cli bundle upload --native-version "2.0.0"
  2. Changements natifs API qui brisent

    Fenêtre de terminal
    # Bundle uses new Capacitor 6 APIs
    npx @capgo/cli bundle upload --native-version "3.0.0"
  3. Migration progressive

    Fenêtre de terminal
    # Test bundle only on latest native version
    npx @capgo/cli bundle upload \
    --channel beta \
    --native-version "2.5.0"

Stratégie 4 : Prévention de la dégradation automatique

Section intitulée « Stratégie 4 : Prévention de la dégradation automatique »

Empêchez les utilisateurs de recevoir des paquets plus anciens que leur version native actuelle.

Dans le tableau de bord Capgo :

  1. Allez à Canaux → Sélectionnez votre canal
  2. Activer « Désactiver la dégradation automatique sous native »
  3. Enregistrer les modifications

Ou via CLI:

Fenêtre de terminal
npx @capgo/cli channel set production --disable-downgrade
  • Appareil de l'utilisateur : Version native 1.2.5
  • Bundle de canal : Version 1.2.3
  • Résultat: Mise à jour bloquée (serait une mise à niveau)

Cela est utile lorsque :

  • Les utilisateurs ont installé manuellement une version plus récente depuis l'app store
  • You devez vous assurer que les utilisateurs disposent toujours des dernières mises à jour de sécurité
  • Vous souhaitez prévenir les bogues de régression

Surcharger l'affectation du canal pour des appareils ou des groupes d'utilisateurs spécifiques.

import { CapacitorUpdater } from '@capgo/capacitor-updater'
// Force beta testers to use v3 channel
async function assignBetaTesters() {
const deviceId = await CapacitorUpdater.getDeviceId()
// Check if user is beta tester
if (isBetaTester(userId)) {
await CapacitorUpdater.setChannel({ channel: 'v3' })
}
}

Dans le tableau de bord Capgo :

  1. Allez à Appareils → Trouvez l'appareil
  2. Cliquez Définir le canal ou Définir la version
  3. Surcharger avec un canal ou une version de bundle spécifique
  4. L'appareil recevra les mises à jour de la source surchargée

Ici, un exemple complet combinant toutes les stratégies :

Fenêtre de terminal
# Create production channel with semver controls
npx @capgo/cli channel create production \
--disable-auto-update major \
--disable-downgrade
capacitor.config.ts
const config: CapacitorConfig = {
plugins: {
CapacitorUpdater: {
autoUpdate: 'atBackground',
defaultChannel: 'production',
}
}
};

2. Mise en production d'une modification de rupture (App v2.0.0)

Section intitulée « 2. Mise en production d'une modification de rupture (App v2.0.0) »
Fenêtre de terminal
# Create v2 channel for new version
npx @capgo/cli channel create v2 \
--disable-auto-update major \
--disable-downgrade \
--self-assign
# Create git branch for v1 maintenance
git checkout -b v1-maintenance
git push origin v1-maintenance
// capacitor.config.ts for v2.0.0
const config: CapacitorConfig = {
plugins: {
CapacitorUpdater: {
autoUpdate: 'atBackground',
defaultChannel: 'v2', // New users get v2 channel
}
}
};
Fenêtre de terminal
# Update v1.x users (bug fix)
git checkout v1-maintenance
# Make changes
npx @capgo/cli bundle upload \
--channel production \
--native-version "1.0.0"
# Update v2.x users (new feature)
git checkout main
# Make changes
npx @capgo/cli bundle upload \
--channel v2 \
--native-version "2.0.0"

Utilisez le tableau de bord Capgo pour suivre :

  • Combien d'utilisateurs sont sur v1 vs v2
  • Taux d'adoption des bundles par version
  • Erreurs ou plantages par version

Lorsque l'utilisation de la version v1 tombe en dessous du seuil :

Fenêtre de terminal
# Stop uploading to production channel
# Optional: Delete v1 maintenance branch
git branch -d v1-maintenance
# Move all remaining users to default
# (They'll need to update via app store)

Lorsqu'il existe plusieurs configurations de canal, Capgo utilise l'ordre de priorité suivant :

  1. Survolage du dispositif (Tableau de bord ou API) - Priorité la plus élevée et visible dans l'interface de Survolage du dispositif
  2. Canal de plugin local via setChannel() - Stocké uniquement sur le dispositif et non affiché dans l'interface de Survolage du dispositif
  3. canal par défaut dans capacitor.config.ts
  4. Canal par défaut (Réglage Cloud) - Priorité la plus basse

1. Définissez toujours defaultChannel pour les Versions majeures

Section intitulée « 1. Définissez toujours defaultChannel pour les Versions majeures »
// ✅ Good: Each major version has explicit channel
// v1.x → production
// v2.x → v2
// v3.x → v3
// ❌ Bad: Relying on dynamic channel switching
// All versions → production, switch manually
Fenêtre de terminal
# ✅ Good
1.0.0 1.0.1 1.1.0 2.0.0
# ❌ Bad
1.0 1.1 2 2.5
Fenêtre de terminal
# ✅ Good: Separate branches per major version
main (v3.x)
v2-maintenance (v2.x)
v1-maintenance (v1.x)
# ❌ Bad: Single branch for all versions
Fenêtre de terminal
# Test on beta channel first
npx @capgo/cli bundle upload --channel beta
# Monitor for issues, then promote to production
npx @capgo/cli bundle upload --channel production

5. Surveiller la distribution des versions

Vérifiez régulièrement votre tableau de bord :

Les utilisateurs se mettent-ils à jour vers les versions natives plus récentes ?

  • Les anciennes versions reçoivent-elles encore un trafic élevé ?
  • Faut-il déprécier les anciens canaux ?
  • Comparaison avec Ionic AppFlow

Pour les équipes en train de migrer depuis Ionic AppFlow, voici comment la version ciblée de Capgo se compare :

CaractéristiqueIonic AppFlowCapgo
Navigation basée sur la versionAutomatique en fonction de la version nativeAutomatique via defaultChannel + plusieurs stratégies
Versionnement semantiqueSupport de baseAvancé avec --disable-auto-update (majeur/minor/patch)
Contraintes de version nativeConfiguration manuelle dans le tableau de bord AppFlowIntégré --native-version drapeau dans CLI
Gestion de canalInterface Web + CLIInterface Web + CLI + API
Survol de dispositifContrôle limité au niveau du dispositifContrôle total via le tableau de bord/API
Prévention de la désactivation automatiqueOuiOui via --disable-downgrade
Maintenance de plusieurs versionsGestion manuelle de branchement/canalAutomatisé avec priorité de canal
Hébergement autoNonOui (contrôle total)
Analytique de versionBasInformations détaillées par version

Les utilisateurs ne reçoivent pas les mises à jour

Section intitulée « Les utilisateurs ne reçoivent pas les mises à jour »

Vérifiez les éléments suivants :

  1. Affectation du canal: Vérifiez que le dispositif est sur le canal correct

    const channel = await CapacitorUpdater.getChannel()
    console.log('Current channel:', channel)
  2. Contraintes de version: Vérifiez si le bundle a des exigences de version natives

    • Tableau de bord → Bundles → Vérifiez la colonne « Version native »
  3. Paramètres Semver: Vérifiez les paramètres du canal « disable-auto-update paramètre

    Fenêtre de terminal
    npx @capgo/cli channel list
  4. Surcharge de dispositif: Vérifiez si le dispositif a une surcharge manuelle

    • Tableau de bord → Appareils → Recherche d'appareil → Vérification de la chaîne/version
  1. Vérification de la chaîne par défaut: Assurez-vous de la bonne chaîne dans capacitor.config.ts
  2. Vérification de l'envoi du bundle: Vérifiez si le bundle a été envoyé à la bonne chaîne
  3. Inspection de la version native: Confirmez que --native-version flag a été utilisé correctement
  1. Réparation immédiate: Surcharger les appareils affectés vers un bundle sécurisé
    • Tableau de bord → Appareils → Sélection multiple → Définir la version
  2. Réparation à long terme: Créer des canaux versionnés et maintenir des branches séparées
  3. Prévention: Tester toujours les mises à jour sur des appareils représentatifs avant le lancement

Mise à niveau depuis Ionic AppFlow

Sous-titre “Mise à niveau depuis Ionic AppFlow”

Si vous migrez depuis Ionic AppFlow, la cible de version fonctionne très de manière similaire dans Capgo, avec une flexibilité améliorée :

AppFlow ConceptCapgo ÉquivalentNotes
Canal de DéploiementCapgo CanalMême concept, plus puissant
Verrouillage de la Version Native--native-version flagPlus de contrôle granulaire
Priorité du CanalPréférence de canal (définir → cloud → par défaut)Préférence de canal plus transparente
Cible de déploiementContrôle de canal + semverPlusieurs stratégies disponibles
Canal de productionproduction Nom de canal (ou n'importe quel nom)Nom de canal flexible
Déploiement basé sur GitCLI téléchargement de paquet depuis la brancheMême flux de travail
Compatibilité de version automatiquedefaultChannel + contraintes de versionAmélioré avec plusieurs stratégies

Différences clés pour les utilisateurs d'AppFlow

Section intitulée “Différences clés pour les utilisateurs d'AppFlow”
  1. Plus de contrôle: Capgo vous offre plusieurs stratégies (canaux, semver, version native) qui peuvent être combinées
  2. Une meilleure visibilité: Le tableau de bord montre la distribution des versions et les problèmes de compatibilité
  3. API Access: Contrôle programmatique complet sur la cible de version
  4. Auto-hébergement: Option de lancer votre propre serveur d'actualisation avec la même logique de version
  1. Cartographiez vos canaux AppFlow vers Capgo canaux (généralement 1:1)
  2. Configurez defaultChannel dans capacitor.config.ts pour chaque version majeure
  3. Configurez les règles de semver s'il vous plaît, bloquez automatiquement à la frontière de version
  4. Téléchargez des ensembles de versions spécifiques en utilisant --native-version flag
  5. Répartition de la version de surveillance dans le tableau de bord Capgo
// Gradually migrate v1 users to v2
async function migrateUsers() {
const deviceId = await CapacitorUpdater.getDeviceId()
const rolloutPercentage = 10 // Start with 10%
// Hash device ID to get deterministic percentage
const hash = hashCode(deviceId) % 100
if (hash < rolloutPercentage) {
// User is in rollout group - migrate to v2
await CapacitorUpdater.setChannel({ channel: 'v2' })
}
}
// Enable features based on native version
async function checkFeatureAvailability() {
const info = await CapacitorUpdater.getDeviceId()
const nativeVersion = info.nativeVersion
if (compareVersions(nativeVersion, '2.0.0') >= 0) {
// Enable features requiring v2.0.0+
enableNewCameraFeature()
}
}
// Run A/B tests within same native version
async function assignABTest() {
const nativeVersion = await getNativeVersion()
if (nativeVersion.startsWith('2.')) {
// Only A/B test on v2 users
const variant = Math.random() < 0.5 ? 'v2-test-a' : 'v2-test-b'
await CapacitorUpdater.setChannel({ channel: variant })
}
}

Capgo fournit plusieurs stratégies pour la livraison d'actualisations spécifiques à la version :

  1. Routage basé sur le canal: Séparation automatique de la version via defaultChannel
  2. : Prévenir les mises à jour à travers les limites de version majeure/minor/patch: Prévenir les mises à jour à travers les limites de version majeure/minor/patch
  3. Contraintes de version native: Exigez une version native minimale pour les ensembles
  4. Prévention de la dégradation automatique: N'envoyez jamais des versions plus anciennes aux versions natives plus récentes
  5. Surcharge de dispositif: Contrôle manuel pour le test et la cible

En combinant ces stratégies, vous pouvez atteindre une mise à jour automatique AppFlow-style avec encore plus de flexibilité et de contrôle. Choisissez l'approche qui convient le mieux à la version et à la stratégie de déploiement de votre application.

Pour plus de détails sur les fonctionnalités spécifiques :

Si vous utilisez Ciblage de version pour planifier la routage de canal et la mise en production étape par étape, connectez-le avec Canaux pour les détails d'implémentation dans Canaux, Canaux pour les détails d'implémentation dans Canaux, Canaux pour les détails d'implémentation dans les canaux, Solution de test bêta pour le flux de travail du produit dans la Solution de test bêta, et Solution de ciblage de version pour le flux de travail du produit dans la Solution de ciblage de version.