Objetivos de versión
Copie una solicitud de configuración con los pasos de instalación y la guía de markdown completa para este complemento.
de manera similar al enfoque de Ionic AppFlow similar a la forma en que Ionic AppFlow lo hace. Esto garantiza un manejo de actualizaciones simplificado y una implementación más rápida, mientras se evitan problemas de compatibilidad.
Capgo’s version targeting system allows you to:
- Evita cambios que rompan la aplicación Automáticamente entrega actualizaciones compatibles
- a los usuarios según su versión nativa de la aplicación evitar versiones de aplicaciones incompatibles
- Administrar múltiples versiones de aplicaciones simultáneamente sin lógica compleja
- Implementar actualizaciones de manera fluida a segmentos de usuarios específicos
¿Por qué la versión de destino es importante (sobre todo para usuarios de AppFlow)?
Sección titulada “¿Por qué la versión de destino es importante (sobre todo para usuarios de AppFlow)?”Si estás familiarizado con Ionic AppFlow, sabrás cuán crítico es asegurarse de que los usuarios reciban solo actualizaciones compatibles. AppFlow automatizó la coincidencia de paquetes de actualizaciones en vivo con versiones nativas de aplicaciones, evitando que se entregara JavaScript incompatibilidad a versiones nativas antiguas code.
Capgo ofrece las mismas garantías de seguridad, con características adicionales:
- Más control granular sobre la coincidencia de versiones
- Múltiples estrategias (canales, semver, restricciones nativas)
- Mejor visibilidad en la distribución de versiones
- API y CLI controlan junto con la gestión de la consola
Esta aproximación es particularmente útil cuando:
- Tienes usuarios en diferentes versiones principales de tu aplicación (por ejemplo, v1.x, v2.x, v3.x)
- Necesitas mantener la compatibilidad hacia atrás mientras se implementan cambios rotos
- Quieres evitar que los paquetes más nuevos rompan los code nativos más antiguos
- Estás migrando a los usuarios gradualmente de una versión a otra
- Estás migrando desde AppFlow y quieres mantener la misma seguridad de actualización
Cómo Funciona
Sección titulada “Cómo Funciona”Capgo utiliza un enfoque multiestratificado para emparejar a los usuarios con actualizaciones compatibles:
- Restricciones de Versión Nativa: Evita que los paquetes se entreguen a versiones nativas incompatibles
- Ruteo Basado en Canales: Ruta diferentes versiones de la aplicación a diferentes canales de actualización
- Controles de Versionado Semántico: Bloquea automáticamente actualizaciones a lo largo de fronteras de versión mayor/minor/patch
- Sobrescrituras a Nivel de Dispositivo: Dirige a dispositivos o grupos de usuarios específicos
Flujo de Emparejamiento de Versión
Sección titulada “Flujo de Emparejamiento de Versión”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]Estrategia 1: Ruta de versión basada en canales
Sección titulada “Estrategia 1: Ruta de versión basada en canales”Esta es la enfoque recomendado para gestionar cambios importantes y actualizaciones de versión mayor. Es similar al modelo de entrega de AppFlow.
Escenario de ejemplo
Sección titulada “Escenario de ejemplo”- App v1.x (100,000 usuarios) →
productioncanales - App v2.x (50,000 usuarios con cambios de ruptura) →
v2canal - App v3.x (10,000 usuarios beta) →
v3canal
Implementación
Paso 1: Configurar canales para cada versión mayorPaso 1: Configurar canales para cada versión mayor
Copiar a portapapeles// 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: true, 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: true, 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: true, defaultChannel: 'v3', // Routes v3 users automatically } }};Paso 2: Crear canales
Sección titulada “Paso 2: Crear canales”# 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-assignPaso 3: Subir paquetes específicos de versión
Sección titulada “Paso 3: Subir paquetes específicos de versión”# 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 v3Ventajas
Sección titulada “Ventajas”- Cero code cambios - La ruta de canal sucede automáticamente
- Separación clara - Cada versión tiene su propio pipeline de actualizaciones
- Diseño flexible - Se pueden enviar actualizaciones a grupos de versiones específicas
- Implementación segura - Los cambios disruptivos nunca llegan a versiones incompatibles
Estrategia 2: Controles de versionamiento semántico
Sección titulada “Estrategia 2: Controles de versionamiento semántico”Use Capgo’s built-in semantic versioning controls to prevent updates across version boundaries.
Deshabilitar actualizaciones automáticas entre versiones principales.
Sección titulada “Deshabilitar actualizaciones automáticas entre versiones principales”.# Create a channel that blocks major version updatesnpx @capgo/cli channel create stable --disable-auto-update majorEsta configuración significa:
- Los usuarios con la versión de la aplicación 1.2.3 recibirán actualizaciones hasta 1.9.9
- Los usuarios no recibirán la versión automáticamente. 2.0.0 No se realizarán actualizaciones automáticas para versiones mayores.
- Evita que los cambios de ruptura lleguen a versiones nativas code
Opciones de control granulares
Sección titulada “Opciones de control granulares”# 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 updatesnpx @capgo/cli channel set stable --disable-auto-update noneSección titulada “Estrategia 3: Restricciones de versión nativa”
Establece requisitos de versión nativa mínimos para los paquetes para evitar la entrega a dispositivos incompatibles.Formato
Usando nativeVersion Retraso Condición
Sección titulada “Usando nativeVersion Retraso Condición”Cuando subas un paquete, puedes especificar una versión nativa mínima:
# This bundle requires native version 2.0.0 or highernpx @capgo/cli bundle upload \ --channel production \ --native-version "2.0.0"Uso de Casos
Sección titulada “Uso de Casos”-
Necesario Nuevo Plugin Nativo
Ventana de terminal # Bundle needs Camera plugin added in v2.0.0npx @capgo/cli bundle upload --native-version "2.0.0" -
Cambios nativos de API
Ventana de terminal # Bundle uses new Capacitor 6 APIsnpx @capgo/cli bundle upload --native-version "3.0.0" -
Migración gradual
Ventana de terminal # Test bundle only on latest native versionnpx @capgo/cli bundle upload \--channel beta \--native-version "2.5.0"
Prevenir la degradación automática
Sección titulada “Prevenir la degradación automática”Evitar que los usuarios reciben paquetes más antiguos que su versión nativa actual.
Habilitar en Configuración de canal
Sección titulada “Habilitar en Configuración de canal”En la consola de Capgo:
- Vaya a Canales → Seleccione su canal
- Habilitar “Deshabilitar la actualización automática nativa”
- Guardar cambios
O a través de CLI:
npx @capgo/cli channel set production --disable-downgradeEjemplo
Sección titulada “Ejemplo”- Dispositivo del usuario: Versión nativa 1.2.5
- Paquete de canal: Versión 1.2.3
- Resultado: La actualización está bloqueada (sería una actualización a una versión anterior)
Esto es útil cuando:
- Los usuarios instalaron manualmente una versión más reciente desde la tienda de aplicaciones
- Necesita asegurarse de que los usuarios siempre tengan las últimas actualizaciones de seguridad
- Quiere prevenir errores de regresión
Estrategia 5: Targetización a nivel de dispositivo
Sección titulada “Estrategia 5: Targetización a nivel de dispositivo”Sobreescribir la asignación de canal para dispositivos o grupos de usuarios específicos.
Forzar una versión específica para pruebas
Sección titulada “Forzar Versión Específica para Pruebas”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' }) }}Panel de control Opción de dispositivo
Sección titulada “Opción de dispositivo de Panel de control”En el panel de control Capgo:
- Ir a Dispositivos → Encontrar dispositivo
- Hacer clic Establecer canal o Establecer versión
- Sobreescribir con una versión específica de canal o paquete
- El dispositivo recibirá actualizaciones desde la fuente sobrescrita
Completa Flujo de Trabajo AppFlow-Style
Aquí hay un ejemplo completo que combina todas las estrategias:1. Configuración inicial (App v1.0.0)
Ventana de terminal
Copiar a portapapeles# Create production channel with semver controlsnpx @capgo/cli channel create production \ --disable-auto-update major \ --disable-downgradeconst config: CapacitorConfig = { plugins: { CapacitorUpdater: { autoUpdate: true, defaultChannel: 'production', } }};2. Cambio de versión (App v2.0.0)
Sección titulada “2. Cambio de versión (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: true, defaultChannel: 'v2', // New users get v2 channel } }};3. Empujar actualizaciones a ambas versiones
Sección titulada “3. Empujar actualizaciones a ambas versiones”# 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. Monitorear distribución de versiones
Sección titulada “4. Distribución de versiones”Utilice el Capgo panel para seguir:
- ¿Cuántos usuarios están en v1 vs v2
- Tasas de adopción de paquetes por versión
- Errores o fallas por versión
5. Deprecar Versión Antigua
Sección titulada “5. Deprecar Versión Antigua”Una vez que el uso de v1 caiga por debajo del umbral:
# 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)Precedencia de canales
Sección titulada “Precedencia de canales”Cuando existen múltiples configuraciones de canales, Capgo utiliza este orden de precedencia:
- Sobrescrito de dispositivo (Panel o API) - Mayor prioridad
- Sobrescrito de Cloud a través de
setChannel()llamada - canales predeterminados en capacitor.config.ts
- Canales predeterminados (Configuración de Cloud) - Menor prioridad
Prácticas recomendadas
Sección titulada “Prácticas recomendadas”1. Establecer siempre defaultChannel para versiones principales
Sección titulada “1. Establecer siempre defaultChannel para versiones principales”// ✅ 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. Utilizar la versión semántica
Sección titulada “2. Utilizar la versión semántica”# ✅ Good1.0.0 → 1.0.1 → 1.1.0 → 2.0.0
# ❌ Bad1.0 → 1.1 → 2 → 2.53. Mantener ramas separadas
Sección titulada “3. Mantener ramas separadas”# ✅ Good: Separate branches per major versionmain (v3.x)v2-maintenance (v2.x)v1-maintenance (v1.x)
# ❌ Bad: Single branch for all versions4. Probar antes de la implementación
Sección titulada “4. Probar antes de la implementación”# Test on beta channel firstnpx @capgo/cli bundle upload --channel beta
# Monitor for issues, then promote to productionnpx @capgo/cli bundle upload --channel production5. Monitorear distribución de versiones
Sección titulada “5. Monitorear distribución de versiones”Revisa regularmente tu panel de control:
- ¿Los usuarios están actualizando a versiones nativas más recientes?
- ¿Las versiones antiguas siguen recibiendo un alto tráfico?
- ¿Deberías deprecar los canales antiguos?
Comparación con Ionic AppFlow
Sección titulada “Comparación con Ionic AppFlow”Para equipos que están migrando desde Ionic AppFlow, aquí está cómo la versión de Capgo se compara con respecto a la versión:
| Característica | Ionic AppFlow | Capgo |
|---|---|---|
| Ruteo basado en versión | Basado automáticamente en la versión nativa | Basado automáticamente a través de defaultChannel + varias estrategias |
| Versión semántica | Soporte básico | Avanzado con --disable-auto-update (mayor/minor/patch) |
| Restricciones de versión nativa | Configuración manual en la consola de AppFlow | Integrado --native-version bandera en CLI |
| Gestión de canales | Interfaz web + CLI | Interfaz web + CLI + API |
| Sobreescribir dispositivos | Control limitado a nivel de dispositivo | Control total a través de la consola/API |
| Prevención de downgrade automático | Sí | Sí a través de --disable-downgrade |
| Mantenimiento de varias versiones | Gestión de rama y canal manual | Automatizado con prioridad de canal |
| Autohospedaje | No | Sí (control completo) |
| Análisis de versiones | Básico | Métricas detalladas por versión |
Solución de problemas
Sección titulada “Solución de problemas”Usuarios No Están Recebiendo Actualizaciones
Sección titulada “Usuarios No Están Recebiendo Actualizaciones”Verifique lo siguiente:
-
Asignación de Canal: Verifique que el dispositivo está en el canal correcto
const channel = await CapacitorUpdater.getChannel()console.log('Current channel:', channel) -
Restricciones de Versión: Verifique si el paquete tiene requisitos de versión nativa
- Panel de control → Paquetes → Verifique la columna “Versión Nativa”
-
Configuración de Semver: Verifique la configuración del canal
disable-auto-update__CAPGO_KEEP_0__Ventana de terminal npx @capgo/cli channel list -
Override de dispositivo: Verificar si el dispositivo tiene override manual
- Panel de control → Dispositivos → Buscar dispositivo → Verificar canal/versión
Paquete entregado a la versión incorrecta
Sección titulada “Paquete entregado a la versión incorrecta”- Revisar defaultChannel: Asegurarse de que el canal sea correcto en
capacitor.config.ts - Verificar carga de paquete: Verificar si el paquete se subió al canal deseado
- Inspeccionar versión nativa: Confirm
--native-versionse utilizó correctamente
Cambios importantes que afectan versiones antiguas
Sección titulada “Cambios importantes que afectan versiones antiguas”- Solución inmediata: Sobreescribir dispositivos afectados para paquete seguro
- Panel de control → Dispositivos → Selección en bloque → Establecer Versión
- Solución a largo plazo: Crear canales versionados y mantener ramas separadas
- Prevención: Siempre probar actualizaciones en dispositivos representativos antes de la implementación
Migración desde Ionic AppFlow
Sección titulada “Migración desde Ionic AppFlow”Si estás migrando desde Ionic AppFlow, la versión objetivo funciona muy de manera similar en Capgo, con una mayor flexibilidad:
Mapeo de Conceptos
Sección titulada “Mapeo de Conceptos”| Concepto de AppFlow | Capgo Equivalente | Notas |
|---|---|---|
| Canales de Despliegue | Capgo Canal | Mismo concepto, más potente |
| Bloqueo de Versión Nativa | --native-version flag | Más control granular |
| Prioridad de Canal | Precedencia de Canal (sobreescribir → nube → predeterminado) | Precedencia más transparente |
| Destino de Despliegue | Canal + semver controla | Disponibles varias estrategias |
| Canal de Producción | production canal (o cualquier nombre) | Nombres flexibles |
| Despliegue basado en Git | CLI carga de paquete desde rama | Mismo flujo de trabajo |
| Compatibilidad automática | defaultChannel Restricciones de versión + | Mejorado con múltiples estrategias |
Diferencias clave para usuarios de AppFlow
Sección titulada “Diferencias clave para usuarios de AppFlow”- Más control: Capgo te da múltiples estrategias (canales, semver, versión nativa) que se pueden combinar
- Visibilidad mejorada: La consola muestra la distribución de versiones y problemas de compatibilidad
- API Acceso: Control completo programático sobre la versión objetivo
- Autoalojamiento: Opción para ejecutar tu propio servidor de actualizaciones con la misma lógica de versión
Pasos de Migración
Sección titulada “Pasos de Migración”- Asigna tus canales de AppFlow a los canales Capgo (usualmente 1:1)
- Establece
defaultChannelencapacitor.config.tspara cada versión mayor - Configura reglas de semver si deseas bloqueo automático en límites de versión
- Subir conjuntos de versiones específicas utilizando
--native-versionflag - Monitorear distribución de versiones en la consola de Capgo
Patrones Avanzados
Sección titulada “Patrones Avanzados”Despliegue gradual por versión
Sección titulada “Despliegue gradual por versión”// 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' }) }}Banderas de características por versión
Sección titulada “Banderas de características por versión”// 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() }}Pruebas A/B entre versiones
Sección titulada “Pruebas A/B entre versiones”// 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 }) }}Resumen
Sección titulada “Resumen”Capgo ofrece varias estrategias para la entrega de actualizaciones específicas de versión:
- Ruta basada en canales: Separación de versiones automática mediante
defaultChannel - Versión semántica: Evita actualizaciones a través de fronteras de versión mayor/minor/patch
- Restricciones de versión nativa: Requiere la versión mínima nativa para paquetes
- Prevención de descenso automático: Nunca entrega paquetes más antiguos a versiones nativas más nuevas
- Sobrescrituras de dispositivo: Control manual para pruebas y targeting
Al combinar estas estrategias, puedes lograr la entrega automática de actualizaciones con estilo de AppFlow, con aún más flexibilidad y control. Elige el enfoque que mejor se adapte al flujo de versión y despliegue de tu aplicación.
Para obtener más detalles sobre características específicas:
- Guía de cambios protegidos - Estrategia de versión de canales detallada
- Gestión de canales - Referencia completa de configuración de canales
- Comportamiento de actualización - Retrasos y condiciones de versión nativa