Ciblage de Version
Copiez un prompt de configuration avec les étapes d'installation et la guide markdown complète pour ce plugin.
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é.
Vue d'ensemble
Section intitulée « Vue d'ensemble »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
Comment ça marche
Titre de la section « Comment ça marche »Capgo utilise une approche multi-niveaux pour correspondre les utilisateurs avec des mises à jour compatibles :
- Contraintes de version native: Empêcher les bundles d'être livrés à des versions natives incompatibles
- Routage basé sur les canaux: Diriger différentes versions d'applications vers différents canaux de mise à jour
- Contrôles de version sémantique: Bloquer automatiquement les mises à jour à travers les limites majeures/minores/patch
- Survol des appareils: Cibler des appareils spécifiques ou des groupes d'utilisateurs
Flux de correspondance de version
Flux de correspondance de versiongraph 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.
Scénario d’exemple
Section intitulée « Scénario d’exemple »- App v1.x (100 000 utilisateurs) →
productioncanal - App v2.x (50 000 utilisateurs avec des modifications de rupture) →
v2canal - App v3.x (10 000 utilisateurs bêta) →
v3canal
Mise en œuvre
Section intitulée “Mise en œuvre”É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 buildsimport { 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 buildsconst 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 buildsconst config: CapacitorConfig = { appId: 'com.example.app', appName: 'Example App', plugins: { CapacitorUpdater: { autoUpdate: 'atBackground', defaultChannel: 'v3', // Routes v3 users automatically } }};Étape 2 : Créer des canaux
Section intitulée “Étape 2 : Créer des canaux”# Create channels for each major versionnpx @capgo/cli channel create productionnpx @capgo/cli channel create v2npx @capgo/cli channel create v3
# Enable self-assignment so apps can switch channelsnpx @capgo/cli channel set production --self-assignnpx @capgo/cli channel set v2 --self-assignnpx @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”# For v1.x users (from v1-maintenance branch)git checkout v1-maintenancenpm run buildnpx @capgo/cli bundle upload --channel production
# For v2.x users (from v2-maintenance or main branch)git checkout mainnpm run buildnpx @capgo/cli bundle upload --channel v2
# For v3.x users (from beta/v3 branch)git checkout betanpm run buildnpx @capgo/cli bundle upload --channel v3Avantages
Section intitulée « Avantages »- 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
Stratégie 2 : Contrôle de la version sémantique
Section intitulée « Stratégie 2 : Contrôles de versionnement sémantique »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# Create a channel that blocks major version updatesnpx @capgo/cli channel create stable --disable-auto-update majorLes 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
Options de contrôle granulaire
Section intitulée “Options de contrôle granulaire”# 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 updatesnpx @capgo/cli channel set stable --disable-auto-update noneStratégie 3 : Contraintes de version native
Section intitulée « Stratégie 3 : Contraintes de version native »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 :
# This bundle requires native version 2.0.0 or highernpx @capgo/cli bundle upload \ --channel production \ --native-version "2.0.0"Utilisations
Section intitulée “Utilisations”-
Nouveau plugin natif requis
Fenêtre de terminal # Bundle needs Camera plugin added in v2.0.0npx @capgo/cli bundle upload --native-version "2.0.0" -
Changements natifs API qui brisent
Fenêtre de terminal # Bundle uses new Capacitor 6 APIsnpx @capgo/cli bundle upload --native-version "3.0.0" -
Migration progressive
Fenêtre de terminal # Test bundle only on latest native versionnpx @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.
Activer dans les paramètres du canal
Section intitulée « Activer dans les paramètres du canal »Dans le tableau de bord Capgo :
- Allez à Canaux → Sélectionnez votre canal
- Activer « Désactiver la dégradation automatique sous native »
- Enregistrer les modifications
Ou via CLI:
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
Stratégie 5 : Ciblage au niveau du dispositif
Section intitulée « Stratégie 5 : Ciblage au niveau du dispositif »Surcharger l'affectation du canal pour des appareils ou des groupes d'utilisateurs spécifiques.
Forcer une version spécifique pour les tests
Section intitulée « Forcer une version spécifique pour les tests »import { CapacitorUpdater } from '@capgo/capacitor-updater'
// Force beta testers to use v3 channelasync function assignBetaTesters() { const deviceId = await CapacitorUpdater.getDeviceId()
// Check if user is beta tester if (isBetaTester(userId)) { await CapacitorUpdater.setChannel({ channel: 'v3' }) }}Tableau de bord : Surcharge de l'appareil
Section intitulée « Tableau de bord : Surcharge de l'appareil »Dans le tableau de bord Capgo :
- Allez à Appareils → Trouvez l'appareil
- Cliquez Définir le canal ou Définir la version
- Surcharger avec un canal ou une version de bundle spécifique
- L'appareil recevra les mises à jour de la source surchargée
Flux de travail complet AppFlow-Style
Section intitulée « Flux de travail complet AppFlow »Ici, un exemple complet combinant toutes les stratégies :
1. Configuration initiale (App v1.0.0)
Section intitulée « 1. Configuration initiale (App v1.0.0) »# Create production channel with semver controlsnpx @capgo/cli channel create production \ --disable-auto-update major \ --disable-downgradeconst 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) »# Create v2 channel for new versionnpx @capgo/cli channel create v2 \ --disable-auto-update major \ --disable-downgrade \ --self-assign
# Create git branch for v1 maintenancegit checkout -b v1-maintenancegit push origin v1-maintenance// capacitor.config.ts for v2.0.0const config: CapacitorConfig = { plugins: { CapacitorUpdater: { autoUpdate: 'atBackground', defaultChannel: 'v2', // New users get v2 channel } }};3. Mettre à jour les deux versions
Section intitulée « 3. Mettre à jour les deux versions »# Update v1.x users (bug fix)git checkout v1-maintenance# Make changesnpx @capgo/cli bundle upload \ --channel production \ --native-version "1.0.0"
# Update v2.x users (new feature)git checkout main# Make changesnpx @capgo/cli bundle upload \ --channel v2 \ --native-version "2.0.0"4. Surveiller la distribution des versions
Section intitulée « 4. Surveiller la distribution des versions »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
5. Dépréciation de la version ancienne
Section intitulée “5. Dépréciation de la version ancienne”Lorsque l'utilisation de la version v1 tombe en dessous du seuil :
# Stop uploading to production channel# Optional: Delete v1 maintenance branchgit branch -d v1-maintenance
# Move all remaining users to default# (They'll need to update via app store)Préférence de canal
Section intitulée “Préférence de canal”Lorsqu'il existe plusieurs configurations de canal, Capgo utilise l'ordre de priorité suivant :
- Survolage du dispositif (Tableau de bord ou API) - Priorité la plus élevée et visible dans l'interface de Survolage du dispositif
- Canal de plugin local via
setChannel()- Stocké uniquement sur le dispositif et non affiché dans l'interface de Survolage du dispositif - canal par défaut dans capacitor.config.ts
- Canal par défaut (Réglage Cloud) - Priorité la plus basse
Meilleures Pratiques
Section intitulée « Meilleures Pratiques »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 manually2. Utilisez la versionnement sémantique
Section intitulée « 2. Utilisez la versionnement sémantique »# ✅ Good1.0.0 → 1.0.1 → 1.1.0 → 2.0.0
# ❌ Bad1.0 → 1.1 → 2 → 2.53. Maintenez des branches séparées
Section intitulée « 3. Maintenez des branches séparées »# ✅ Good: Separate branches per major versionmain (v3.x)v2-maintenance (v2.x)v1-maintenance (v1.x)
# ❌ Bad: Single branch for all versions4. Tester avant le lancement
Section intitulée « 4. Tester avant le lancement »# Test on beta channel firstnpx @capgo/cli bundle upload --channel beta
# Monitor for issues, then promote to productionnpx @capgo/cli bundle upload --channel production5. 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
Copier dans le presse-papier
Section intitulée « 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éristique | Ionic AppFlow | Capgo |
|---|---|---|
| Navigation basée sur la version | Automatique en fonction de la version native | Automatique via defaultChannel + plusieurs stratégies |
| Versionnement semantique | Support de base | Avancé avec --disable-auto-update (majeur/minor/patch) |
| Contraintes de version native | Configuration manuelle dans le tableau de bord AppFlow | Intégré --native-version drapeau dans CLI |
| Gestion de canal | Interface Web + CLI | Interface Web + CLI + API |
| Survol de dispositif | Contrôle limité au niveau du dispositif | Contrôle total via le tableau de bord/API |
| Prévention de la désactivation automatique | Oui | Oui via --disable-downgrade |
| Maintenance de plusieurs versions | Gestion manuelle de branchement/canal | Automatisé avec priorité de canal |
| Hébergement auto | Non | Oui (contrôle total) |
| Analytique de version | Bas | Informations détaillées par version |
Dépannage
Section intitulée « Dépannage »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 :
-
Affectation du canal: Vérifiez que le dispositif est sur le canal correct
const channel = await CapacitorUpdater.getChannel()console.log('Current channel:', channel) -
Contraintes de version: Vérifiez si le bundle a des exigences de version natives
- Tableau de bord → Bundles → Vérifiez la colonne « Version native »
-
Paramètres Semver: Vérifiez les paramètres du canal «
disable-auto-updateparamètreFenêtre de terminal npx @capgo/cli channel list -
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
Bundle livré à la mauvaise version
Sous-section intitulée « Bundle livré à la mauvaise version »- Vérification de la chaîne par défaut: Assurez-vous de la bonne chaîne dans
capacitor.config.ts - Vérification de l'envoi du bundle: Vérifiez si le bundle a été envoyé à la bonne chaîne
- Inspection de la version native: Confirmez que
--native-versionflag a été utilisé correctement
Changements de rupture affectant les anciennes versions
Sous-section intitulée « Changements de rupture affectant les anciennes versions »- 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
- Réparation à long terme: Créer des canaux versionnés et maintenir des branches séparées
- 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 :
Cartographie de Concept
Section intitulée « Cartographie de Concept »| AppFlow Concept | Capgo Équivalent | Notes |
|---|---|---|
| Canal de Déploiement | Capgo Canal | Même concept, plus puissant |
| Verrouillage de la Version Native | --native-version flag | Plus de contrôle granulaire |
| Priorité du Canal | Préférence de canal (définir → cloud → par défaut) | Préférence de canal plus transparente |
| Cible de déploiement | Contrôle de canal + semver | Plusieurs stratégies disponibles |
| Canal de production | production Nom de canal (ou n'importe quel nom) | Nom de canal flexible |
| Déploiement basé sur Git | CLI téléchargement de paquet depuis la branche | Même flux de travail |
| Compatibilité de version automatique | defaultChannel + contraintes de version | Amé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”- Plus de contrôle: Capgo vous offre plusieurs stratégies (canaux, semver, version native) qui peuvent être combinées
- Une meilleure visibilité: Le tableau de bord montre la distribution des versions et les problèmes de compatibilité
- API Access: Contrôle programmatique complet sur la cible de version
- Auto-hébergement: Option de lancer votre propre serveur d'actualisation avec la même logique de version
Étapes de migration
Section intitulée « Étapes de migration »- Cartographiez vos canaux AppFlow vers Capgo canaux (généralement 1:1)
- Configurez
defaultChanneldanscapacitor.config.tspour chaque version majeure - Configurez les règles de semver s'il vous plaît, bloquez automatiquement à la frontière de version
- Téléchargez des ensembles de versions spécifiques en utilisant
--native-versionflag - Répartition de la version de surveillance dans le tableau de bord Capgo
Modèles avancés
Section intitulée “Modèles avancés”Déploiement progressif par version
Section intitulée “Déploiement progressif par version”// Gradually migrate v1 users to v2async 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' }) }}Drapeaux de fonctionnalité par version
Section intitulée « Drapeaux de fonctionnalité par version »// Enable features based on native versionasync 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() }}Test A/B à travers les versions
Section intitulée « Test A/B à travers les versions »// Run A/B tests within same native versionasync 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 :
- Routage basé sur le canal: Séparation automatique de la version via
defaultChannel - : 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
- Contraintes de version native: Exigez une version native minimale pour les ensembles
- Prévention de la dégradation automatique: N'envoyez jamais des versions plus anciennes aux versions natives plus récentes
- 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 :
- Guide des changements majeurs - Stratégie de versionnage de canal détaillée
- Gestion de canal - Référence complète de la configuration de canal
- Mise à jour du comportement - Retard et conditions de la version native
Continuer à partir de la ciblage de version
Section intitulée “Continuer à partir de la ciblage de version”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.