Saltare al contenuto

Target di Versione

Questa guida spiega come consegnare automaticamente il bundle più compatibile agli utenti in base alla versione nativa dell'applicazione, simile all'approccio di Ionic AppFlow. Questo garantisce una gestione degli aggiornamenti semplificata e una distribuzione più rapida, mentre prevenendo problemi di compatibilità.

Capgo’s sistema di targeting delle versioni consente di:

  • Distribuire automaticamente aggiornamenti compatibili ai utenti in base alla versione nativa dell'applicazione
  • Prevenire modifiche che rompono il codice da raggiungere versioni di app incompatibili
  • Gestisci diverse versioni di app contemporaneamente senza logica complessa
  • Esegui aggiornamenti senza soluzione di continuità a specifici segmenti di utenti

Perché la versione di targeting è importante (Soprattutto per gli utenti di AppFlow)

Sezione intitolata “Perché la versione di targeting è importante (Soprattutto per gli utenti di AppFlow)”

Se sei familiare con Ionic AppFlow, sai quanto sia cruciale assicurarsi che gli utenti ricevano solo aggiornamenti compatibili. AppFlow ha automaticamente corrisposto pacchetti di aggiornamento live ai bundle nativi, impedendo che JavaScript incompatibile fosse consegnato a versioni native più vecchie di code.

Capgo offre le stesse garanzie di sicurezza, con funzionalità aggiuntive:

  • Maggiore controllo sulla corrispondenza delle versioni
  • Multiple strategie (canali, semver, vincoli nativi)
  • Visibilità migliore nella distribuzione delle versioni
  • API e CLI controllo insieme alla gestione del pannello

Questo approccio è particolarmente utile quando:

  • Hai utenti su diverse versioni maggiori del tuo app (ad esempio, v1.x, v2.x, v3.x)
  • Hai bisogno di mantenere la compatibilità con le versioni precedenti mentre esegui cambiamenti di rottura
  • Vuoi impedire che i bundle più recenti rompano le code native più vecchie
  • Stai migrando gli utenti gradualmente da una versione all'altra
  • Stai migrando da AppFlow e vuoi mantenere la stessa sicurezza degli aggiornamenti

Capgo utilizza un approccio multi-strato per accoppiare gli utenti con aggiornamenti compatibili:

  1. Restrizioni di Versione Nativa: Prevenire i pacchetti da essere consegnati a versioni native incompatibili
  2. Routing basato sui Canali: Inviare versioni diverse dell'app a canali di aggiornamento diversi
  3. Controlli di Versioning Semantico: Bloccare automaticamente gli aggiornamenti ai confini di major/minor/patch
  4. Override di Livello di Dispositivo: Targetare dispositivi specifici o gruppi di utenti
graph TD
A[User Opens App] --> B{Check Device Override}
B -->|Override Set| C[Use Override Channel]
B -->|No Override| D{Check defaultChannel in App}
D -->|Has defaultChannel| E[Use App's defaultChannel]
D -->|No defaultChannel| F[Use Cloud Default Channel]
C --> G{Check Version Constraints}
E --> G
F --> G
G -->|Compatible| H[Deliver Update]
G -->|Incompatible| I[Skip Update]

Questo è il metodo consigliato per gestire i cambiamenti significativi e le aggiornamenti di versione maggiore. È simile al modello di consegna di AppFlow.

  • App v1.x (100.000 utenti) → production canale
  • App v2.x (50.000 utenti con modifiche di rottura) → v2 canale
  • App v3.x (10.000 utenti beta) → v3 canale

Sezione intitolata “Passo 1: Configura i canali per ogni versione maggiore”

Copia negli appunti
// 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
}
}
};
Finestra del terminale
# 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
Finestra del terminale
# 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
  • Zero code modifiche - La routing dei canali avviene automaticamente
  • Separazione chiara - Ogni versione ha il proprio pipeline di aggiornamento
  • Targeting flessibile - Aggiornamenti push per gruppi di versioni specifiche
  • Rollout sicuro - Cambiamenti di versione non raggiungono le versioni incompatibili

Utilizza i controlli di versionamento semantico integrati di Capgo per impedire gli aggiornamenti tra i confini delle versioni.

Disabilita Aggiornamento Automatico Tra Versioni Principali

Sezione intitolata “Disabilita Aggiornamento Automatico Tra Versioni Principali”
Finestra del terminale
# Create a channel that blocks major version updates
npx @capgo/cli channel create stable --disable-auto-update major

Questa configurazione significa:

  • Gli utenti con la versione dell'app 1.2.3 riceveranno gli aggiornamenti fino a 1.9.9
  • Gli utenti non riceveranno la versione automaticamente 2.0.0 Capacitor
  • Previene che i cambiamenti di base non raggiungano le versioni native più vecchie code
Finestra del terminale
# Block minor version updates (1.2.x won't get 1.3.0)
npx @capgo/cli channel set stable --disable-auto-update minor
# Block patch updates (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

Specificare i requisiti minimi di versione native per i pacchetti per prevenire la consegna a dispositivi incompatibili.

Utilizzo della versione nativa Condizione di ritardo

Sezione intitolata “Utilizzo della versione nativa Condizione di ritardo”

Quando si carica un bundle, è possibile specificare una versione minima nativa:

Finestra del terminale
# This bundle requires native version 2.0.0 or higher
npx @capgo/cli bundle upload \
--channel production \
--native-version "2.0.0"
  1. Richiesta di nuovo plugin nativo

    Finestra del terminale
    # Bundle needs Camera plugin added in v2.0.0
    npx @capgo/cli bundle upload --native-version "2.0.0"
  2. Modifiche native di API

    Finestra del terminale
    # Bundle uses new Capacitor 6 APIs
    npx @capgo/cli bundle upload --native-version "3.0.0"
  3. Migrazione graduale

    Finestra del terminale
    # Test bundle only on latest native version
    npx @capgo/cli bundle upload \
    --channel beta \
    --native-version "2.5.0"

Prevenire agli utenti di ricevere pacchetti più vecchi della loro versione nativa corrente.

Nella dashboard Capgo:

  1. Vai a Canali → Seleziona il tuo canale
  2. Abilita “Disabilita l'auto downgrade nativo”
  3. Salva le modifiche

Ora via CLI:

Finestra del terminale
npx @capgo/cli channel set production --disable-downgrade
  • Dispositivo dell'utente: Versione nativa 1.2.5
  • Bundle del canale: Versione 1.2.3
  • Risultato: Aggiornamento bloccato (sarebbe una riduzione di versione)

Questo è utile quando:

  • Gli utenti hanno installato manualmente una versione più recente dall'app store
  • Hai bisogno di assicurarti che gli utenti abbiano sempre le patch di sicurezza più recenti
  • Vuoi prevenire i bug di regressione

Sovrascrivi l'assegnazione del canale per dispositivi o gruppi di utenti specifici.

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' })
}
}

Nel Capgo pannello di controllo:

  1. Vai a Dispositivi → Trova dispositivo
  2. Clicca Imposta canale o Imposta versione
  3. Sostituisci con una versione specifica del canale o del pacchetto
  4. Il dispositivo riceverà aggiornamenti dalla fonte sovrascritta

Flusso di lavoro completo AppFlow-Style

Ecco un esempio completo che combina tutte le strategie:

1. Configurazione iniziale (App v1.0.0)

Finestra del terminale

Copia negli appunti
Sommario
# 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',
}
}
};
Finestra del terminale
# 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
}
}
};
Finestra del terminale
# 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"

4. Monitora la distribuzione delle versioni

Sezione intitolata “4. Distribuzione delle versioni”

Utilizza il dashboard Capgo per monitorare:

  • Quanti utenti sono su v1 vs v2
  • Tassi di adozione dei pacchetti per versione
  • Errori o crash per versione

Una volta che l'utilizzo di v1 scende al di sotto del limite:

Finestra del terminale
# 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)

Quando esistono più configurazioni di canale, Capgo utilizza l'ordine di precedenza seguente:

  1. Override dispositivo (Pannello di controllo o API) - Priorità più alta
  2. Override Cloud via setChannel() chiamata
  3. canale predefinito in capacitor.config.ts
  4. Canale predefinito (impostazione Cloud) - Priorità più bassa

1. Imposta sempre defaultChannel per le Versioni Principali

Sezione intitolata “1. Imposta sempre defaultChannel per le Versioni Principali”
// ✅ 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
Finestra del terminale
# ✅ Good
1.0.0 1.0.1 1.1.0 2.0.0
# ❌ Bad
1.0 1.1 2 2.5
Finestra del terminale
# ✅ Good: Separate branches per major version
main (v3.x)
v2-maintenance (v2.x)
v1-maintenance (v1.x)
# ❌ Bad: Single branch for all versions
Finestra del terminale
# 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

Verifica regolarmente il tuo dashboard:

  • I utenti stanno aggiornando a versioni native più recenti?
  • Le vecchie versioni stanno ancora ricevendo un alto traffico?
  • Dovresti deprecare i vecchi canali?

Per le squadre che stanno migrando da Ionic AppFlow, ecco come la versione di targeting di Capgo si confronta:

CaratteristicaIonic AppFlowCapgo
Routing basato sulla versioneBasato automaticamente sulla versione nativaAutomatico tramite defaultChannel + strategie multiple
Versioning semanticoSupporto baseAvanzato con --disable-auto-update (major/minor/patch)
Restrizioni sulla versione nativaConfigurazione manuale nel dashboard di AppFlowIntegrato --native-version flag in CLI
Gestione del canaleInterfaccia Web + CLIInterfaccia Web + CLI + API
Sovrascritture del dispositivoControllo limitato a livello di dispositivoControllo completo tramite Dashboard/API
Prevenzione del downgrade automaticoSì via --disable-downgrade
Manutenzione delle diverse versioniGestione della branca/canale manualeAutomatizzato con priorità di canale
Auto-impostazioneNoSì (controllo completo)
Analisi delle versioniBaseMetriche dettagliate per versione

Controlla i seguenti elementi:

  1. Assegnazione del canale: Verifica che il dispositivo sia sul canale corretto

    const channel = await CapacitorUpdater.getChannel()
    console.log('Current channel:', channel)
  2. Restrizioni di versione: Controlla se il pacchetto ha richieste di versione native

    • Dashboard → Pacchetti → Controlla la colonna “Versione nativa”
  3. Impostazioni Semver: Verifica le impostazioni del canale disable-auto-update Impostazioni Semver

    Finestra del terminale
    npx @capgo/cli channel list
  4. Override dispositivo: Verifica se il dispositivo ha un override manuale

    • Pannello di controllo → Dispositivi → Cerca dispositivo → Verifica canale/versione
  1. Recensisci defaultChannel: Assicurati di avere il canale corretto in capacitor.config.ts
  2. Verifica l'upload del bundle: Verifica se il bundle è stato caricato sul canale inteso
  3. Ispeziona versione nativa: Conferma --native-version è stata utilizzata correttamente la flag

Cambiamenti Rilevanti che Affectano le Versioni Antiche

Sezione intitolata “Cambiamenti Rilevanti che Affectano le Versioni Antiche”
  1. Soluzione di Emergenza: Imposta i dispositivi colpiti su bundle sicuro
    • Pannello di controllo → Dispositivi → Selezione di massa → Imposta Versione
  2. Soluzione a Lungo Termine: Crea canali versionati e mantieni rami separati
  3. Prevenzione: Testa sempre le aggiornamenti su dispositivi rappresentativi prima della distribuzione

Se stai migrando da Ionic AppFlow, la versione targeting funziona in modo molto simile in Capgo, con maggiore flessibilità:

Concetto AppFlowCapgo EquivalenteNote
Canale di distribuzioneCapgo CanaleLo stesso concetto, ma con maggiore potenza
Blocco Versione Nativa--native-version flagMaggiore controllo granulare
Priorità del CanalePrecedenza del Canale (override → cloud → default)Precedenza più trasparente
Destinazione di DistribuzioneCanale + controlli semverDisponibili diverse strategie
Canale di Produzioneproduction canale (o qualsiasi nome)Nominazione flessibile
Deployimento basato su GitCLI caricamento del pacchetto dall'assegnazioneLo stesso workflow
Compatibilità automatica della versionedefaultChannel Restrizioni di versione più avanzateSviluppato con strategie multiple
  1. Maggiore controllo: Capgo offre strategie multiple (canali, semver, versione nativa) che possono essere combinate
  2. Visibilità migliore: Il dashboard mostra la distribuzione delle versioni e gli eventuali problemi di compatibilità
  3. API Accesso: Controllo completo programmatico sulla versione di destinazione
  4. Auto-hosting: Opzione per eseguire il proprio server di aggiornamento con la stessa logica di versione
  1. Mappa i canali AppFlow a Capgo canali (di solito 1:1)
  2. Impostare defaultChannel in capacitor.config.ts per ogni versione maggiore
  3. Configurare le regole semver Se desideri il blocco automatico ai confini di versione
  4. Carica bundle specifici per versione utilizzando --native-version flag
  5. Monitorare la distribuzione delle versioni nella dashboard di 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 fornisce diverse strategie per la consegna di aggiornamenti specifici per versione:

  1. Routing per Canale: Separazione automatica della versione tramite defaultChannel
  2. Versionamento Semantico: Prevenire gli aggiornamenti attraverso i confini di versione maggiore/minore/patch
  3. Restrizioni di Versione Nativa: Richiedere la versione minima nativa per i pacchetti
  4. Prevenzione del Downgrade Automatico: Non consegnare mai pacchetti più vecchi a versioni native più nuove
  5. Override del Dispositivo: Controllo manuale per la prova e il targeting

Combinate queste strategie per raggiungere il tipo di aggiornamento automatico di AppFlow con ancora più flessibilità e controllo. Scegli l'approccio che meglio si adatta al flusso di versione e di distribuzione del tuo app.

Per ulteriori dettagli sulle funzionalità specifiche: