Saltar al contenido principal
Tutoriales

Navegación entre canales para Capgo: Cómo cambiar entre canales de actualización en tiempo de ejecución

Envía cambios a usuarios específicos de inmediato con la función de cambio de canal en tiempo de ejecución de Capgo. Cambia entre canales de actualización sin reinstalar tu aplicación Capacitor.

Martin Donadieu

Martin Donadieu

Gerente de contenido

Navegación entre canales para Capgo: Cómo cambiar entre canales de actualización en tiempo de ejecución

¿Alguna vez has deseado poder enviar un cambio directamente a un usuario para su revisión y retroalimentación inmediatas - sin pedirles que descarguen e instalen una nueva versión desde TestFlight o Google Play?

He tenido clientes que solicitaron mejoras que pude implementar rápidamente, pero obtener los resultados en sus manos para validar significaba enviar una actualización a todos los usuarios (riesgoso para un cambio experimental) o crear una versión única para el cliente (un trabajo para ambos).

Lo que faltaba era flexibilidad. Los desarrolladores querían poder servir actualizaciones diferentes a diferentes grupos de usuarios, como partes no técnicas, QA o la base de usuarios completa cuando fuera apropiado.

No había una forma de que una versión de producción cambiara a una versión en curso de trabajo, recopilar retroalimentación y luego regresar a la producción.

Eso es lo que cambiar de canal permite. Una aplicación instalada en un dispositivo del usuario puede cambiar el canal de actualizaciones en tiempo de ejecución, convirtiendo una aplicación de producción en un espacio flexible para la revisión e iteración en lugar de un punto final fijo. Esto es especialmente útil para partes no técnicas que trabajan con aplicaciones de producción, permitiéndoles probar cambios y dar retroalimentación directamente en la aplicación que ya tienen instalada.

Entendiendo los canales de actualización

Los canales de actualización son cómo Capgo dirige actualizaciones a versiones específicas. Cada versión está asociada con un canal, y ese canal determina qué actualizaciones recibirá.

Por ejemplo, puedes publicar actualizaciones en un preview canal sin afectar a los usuarios en production. En el pasado, cambiar de canales requería instalar una compilación nativa diferente o cambiar manualmente las asignaciones de dispositivos a través de la consola.

Los canales en Capgo te permiten:

  • Dirigirte a grupos de usuarios específicos con características diferentes
  • Ejecutar pruebas A/B asignando a los usuarios diferentes canales
  • Implementar gradualmente nuevas características
  • Crear programas de pruebas beta
  • Depurar problemas de producción con usuarios individuales

Si no estás familiarizado con los canales de actualización, la Capgo documentación de canales los cubre en mayor detalle.

¿Qué es el Surfado de Canales?

El surfado de canales permite a una aplicación instalada obtener actualizaciones de diferentes flujos sin tener que reinstalarla. Una aplicación instalada puede cambiar de canales de actualización en tiempo de ejecución, y continuará recibiendo actualizaciones del canal seleccionado recientemente hasta que la aplicación sea desinstalada o cambiada a otro canal.

In la práctica, esto significa que un propietario de producto o un QA pueden cambiar una production construcción a, por ejemplo, un preview canal, probar las últimas modificaciones. Cuando terminen de probar, cambian de nuevo a production de nuevo. No hay necesidad de reinstalar o de una construcción de vista previa separada.

Bajo la cubierta, el cambio de canal funciona permitiendo que la aplicación le diga al cliente de actualizaciones qué canal usar. Esa elección puede cambiar en tiempo de ejecución y permanece en efecto hasta que se elimina o se reemplaza.

Cómo Implementar el Cambio de Canal

Antes de que puedas probar el cambio de canal, tu proyecto necesita estar configurado con Capgo Actualizaciones en Vivo. Para configurarlo, sigue el Capgo guía rápida de inicio.

The only setup required for channel surfing is enabling “Allow devices to self associate” on each channel you want to switch to in the Capgo dashboard. code consola.

No hay cambios o modificaciones de configuración API necesarias más allá de eso.

import { CapacitorUpdater } from '@capgo/capacitor-updater';

await CapacitorUpdater.setChannel({ channel: 'your-channel' });

En su núcleo, el cambio de canal está impulsado por una sola llamada de Capgo : Aprende más sobre el setChannel API.

Intercambio de canales instantáneo (v5.34.0+)

Desde la versión del plugin 5.34.0, 6.34.0, 7.34.0 o 8.0.0 (dependiendo de tu versión principal), setChannel() funciona de manera diferente y mucho más rápida:

  1. Validación de backend (solo lectura): Se envía una solicitud al Capgo backend para validar que la canal sea permitido
  2. Actualización de almacenamiento local: Si la validación pasa, el canal se guarda en el almacenamiento local del dispositivo
  3. Effecto instantáneo: La próxima verificación de actualizaciones utiliza el nuevo canal de inmediato

Anteriormente, setChannel() guardó la sobrescritura del canal en la base de datos del backend (como Dashboard o API cambios). Los dispositivos tuvieron que esperar la replicación del backend (hasta 2 minutos) antes de que el nuevo canal fuera reconocido. El nuevo comportamiento solo lee del backend (para la validación) y almacena localmente, lo que hace que los cambios de canal sean instantáneos.

Flujo de Cambio de Canal Completo

Para una mejor experiencia del usuario, normalmente querrás hacer más que simplemente cambiar el canal y esperar al próximo reinicio de la aplicación. Una aproximación común es verificar inmediatamente actualizaciones, descargarlas si están disponibles y recargar la aplicación para que el usuario aterrice directamente en la actualización seleccionada del canal.

Un flujo típico se ve así:

  1. Cambiar el canal (setChannel)
  2. Verificar una actualización (getLatest)
  3. Obtener y aplicar la actualización (download, set o next)
  4. Recargar la aplicación si es necesario (reload)

Aquí hay un ejemplo completo:

import { CapacitorUpdater } from '@capgo/capacitor-updater';

async function switchChannel(selectedChannel: string) {
  try {
    // 1. Set the updates channel (with optional auto-update trigger)
    await CapacitorUpdater.setChannel({
      channel: selectedChannel,
      triggerAutoUpdate: true // Immediately check for updates
    });

    console.log(`Switched to channel: ${selectedChannel}`);

    // If you want more control, handle the update manually:
    // const latest = await CapacitorUpdater.getLatest();
    // if (latest.url) {
    //   const bundle = await CapacitorUpdater.download({
    //     url: latest.url,
    //     version: latest.version
    //   });
    //   await CapacitorUpdater.set({ id: bundle.id });
    // }

  } catch (error) {
    console.error('Failed to switch channel:', error);
  }
}

// Switch to the beta channel
switchChannel('beta');

La forma en que estructures este flujo es a tu elección. Puedes dividir estos pasos en múltiples interacciones o ejecutarlos todos a la vez. Independientemente de cómo estructures el flujo, asegúrate de tener en cuenta los errores. Problemas de red o un canal inválido pueden impedir que se aplique una actualización.

El Único Requisito: Habilitar Autoasignación

Esta es la única cosa que debes hacer para habilitar el cambio de canal. Antes de que tu aplicación pueda cambiar a un canal utilizando setChannel(), debes habilitar la autoasignación para ese canal en la consola de Capgo:

  1. Ve a la sección Canales en tu consola de Capgo
  2. Haz clic en el nombre del canal que deseas gestionar
  3. Habilita “Allow devices to self associate”
  4. Permitir a los dispositivos autoasociarse"

Guardar los cambios

Habilita la autoasignación en los ajustes del canal defaultChannel setting requerido. Solo habilite la autoasignación en los canales que desee que los usuarios puedan cambiar a.

Si se deshabilita esta configuración, cualquier intento de llamar setChannel() con este canal fallará y se disparará el channelPrivate evento.

Lista de Canales Disponibles

Puede obtener la lista de canales disponibles para la autoasignación:

const { channels } = await CapacitorUpdater.listChannels();

console.log('Available channels:', channels.map(c => c.name));
// Use this to build a channel selector UI

Esto solo devuelve canales donde la autoasignación está habilitada.

Obtener el Canal Actual

Verifique qué canal está asignado actualmente al dispositivo:

const { channel } = await CapacitorUpdater.getChannel();

console.log('Current channel:', channel);

Revertir a Canal Predeterminado

Para eliminar la sobrescritura de canal y regresar a la predeterminada:

await CapacitorUpdater.unsetChannel({});

Esto desvincula el dispositivo de cualquier canal asignado específicamente, causando que regrese a la defaultChannel In su configuración o el valor por defecto de la nube.

Cómo Probar el Surf de Canales

Para ver el surf de canales en acción, necesitarás una compilación de lanzamiento - el __CAPGO_KEEP_0__ está diseñado para compilaciones de lanzamiento. En compilaciones de depuración, la aplicación carga típicamente JavaScript de un servidor de desarrollo en lugar de eso, lo que evita el flujo de actualización normal. @capgo/capacitor-updater API is designed for release builds. In debug builds, the app typically loads JavaScript from a development server instead, which bypasses the normal update flow.

El único requisito para el surf de canales es habilitar

“Permitir que los dispositivos se asocie de forma autónoma” en cada canal que desee permitir cambiar a. No se necesitan cambios de configuración en tu aplicación. Creando una Compilación de Prueba

Compila tu aplicación de manera habitual:

Luego crea tus compilaciones nativas utilizando Xcode o Android Studio, o utiliza tu pipeline de CI/CD. La aplicación comenzará en el canal que se establezca como valor por defecto en la nube en tu panel de control __CAPGO_KEEP_0__.

bun run build && npx cap sync

Then create your native builds using Xcode or Android Studio, or use your CI/CD pipeline. The app will start on whichever channel is set as the cloud default in your Capgo dashboard.

Publicando Actualizaciones en Diferentes Canales

Una vez que la aplicación está instalada, publica actualizaciones a diferentes canales:

# Publish to preview channel
npx @capgo/cli@latest bundle upload --channel preview

# Publish to production channel
npx @capgo/cli@latest bundle upload --channel production

Desde allí, navega a tu interfaz de navegación por canales en la aplicación y activa el cambio de canal. La aplicación debería descargar la actualización del canal seleccionado y recargar en la nueva actualización.

Crear una interfaz de cambio de canal

La navegación por canales es algo que normalmente deseas exponer a un conjunto limitado de usuarios, no a todos los que utilizan tu aplicación. Por ejemplo, podrías tener un botón disponible solo para empleados autenticados que cambia la aplicación al canal de prueba.

Aquí tienes un ejemplo de componente de React para un cambio de canal:

import { useState, useEffect } from 'react';
import { CapacitorUpdater } from '@capgo/capacitor-updater';

export function ChannelSwitcher() {
  const [currentChannel, setCurrentChannel] = useState<string>('');
  const [availableChannels, setAvailableChannels] = useState<string[]>([]);
  const [isLoading, setIsLoading] = useState(false);

  useEffect(() => {
    loadChannelInfo();
  }, []);

  async function loadChannelInfo() {
    const { channel } = await CapacitorUpdater.getChannel();
    setCurrentChannel(channel || 'default');

    const { channels } = await CapacitorUpdater.listChannels();
    setAvailableChannels(channels.map(c => c.name));
  }

  async function handleChannelSwitch(channel: string) {
    setIsLoading(true);
    try {
      await CapacitorUpdater.setChannel({
        channel,
        triggerAutoUpdate: true
      });
      setCurrentChannel(channel);
      // App will update in background or on next restart
    } catch (error) {
      console.error('Failed to switch channel:', error);
    } finally {
      setIsLoading(false);
    }
  }

  return (
    <div>
      <p>Current channel: {currentChannel}</p>
      <div>
        {availableChannels.map(channel => (
          <button
            key={channel}
            onClick={() => handleChannelSwitch(channel)}
            disabled={isLoading || channel === currentChannel}
          >
            Switch to {channel}
          </button>
        ))}
      </div>
    </div>
  );
}

Problemas de actualización OTA

Ninguno de estos es específico de la navegación por canales, pero tienden a volverse evidentes rápidamente una vez que comiences a cambiar canales en tiempo de ejecución.

Incompatibilidades de versión en tiempo de ejecución

Las actualizaciones en Capgo están vinculadas a versiones nativas de la aplicación. Si la versión nativa de una actualización no coincide con la versión nativa de la aplicación instalada, la actualización no se descargará ni se aplicará. Cuando se navega por canales, esto suele aparecer como la aplicación cambiando de canales pero sin que se aplique la actualización, aunque una exista en ese canal.

Normalmente significa que la actualización se publicó desde una versión nativa diferente de la aplicación. Asegúrate de que el paquete de tu canal sea compatible con la versión nativa instalada en el dispositivo.

Eliminar o deshacer actualizaciones

Si una aplicación ya ha descargado una actualización para un canal, eliminar esa actualización desde la consola de Capgo no la elimina de los dispositivos que ya la tienen. La eliminación solo detiene la descarga de la actualización en los dispositivos que ya la han descargado. idioma futuro. descargas.

La forma más confiable de deshacer una actualización mala es publicar una actualización conocida como buena en el mismo canal. Esto crea una nueva actualización en la parte superior de la historia del canal, que los clientes tratarán como la versión más reciente y aplicarán en su lugar.

Capgo también proporciona un mecanismo de retroceso que puede instruir a los clientes a re-aplicar una actualización estable anterior o regresar a la actualización incorporada en la compilación.

Consideraciones de migración de datos

Cambiar de canal cambia el paquete de JavaScript que ejecuta la aplicación. Si su aplicación depende de migraciones o formas de datos que no son compatibles entre canales, cambiar de un lado a otro puede causar problemas.

Por ejemplo, si una actualización de beta aplica una migración de base de datos, la versión de producción no entenderá el nuevo esquema. Los desarrolladores deben asegurarse de que sus actualizaciones permanezcan seguras para cambiar entre ellas o restrinjan el cambio a una dirección cuando sea necesario.

¿Por qué el surf de canales mejora la iteración móvil?

El surf de canales es especialmente útil cuando necesita revisar cambios rápidamente en un entorno de producción.

Validación Rápida

Imagine una corrección urgente de un bug que necesita validación antes de ser lanzada ampliamente. Con el surf de canales, el cambio puede ser aislado a un pequeño conjunto de usuarios designados que pueden revisarlo antes de que llegue a la producción.

Revisión de partes interesadas

Un propietario de producto o un especialista en pruebas puede cambiar su instalación de producción a otro canal de actualización, verificar la corrección o la característica, y luego cambiar de nuevo una vez que estén listos.

Pruebas Simplificadas

Esto facilita la participación de partes interesadas no técnicas en la revisión y la toma de decisiones, mientras se mantiene el flujo de trabajo suave. Una sola instalación de producción se convierte en una herramienta flexible para la prueba, la retroalimentación y la validación.

Casos de Uso

  • Pruebas de QA: Que el equipo de pruebas pueda cambiar entre ramas de características
  • Programas Beta: Los usuarios se optan por el canal beta para el acceso temprano
  • Revisión de partes interesadas: Los propietarios de producto pueden previsualizar los cambios antes de la liberación
  • Pruebas A/B: Asignar usuarios a diferentes canales para experimentos
  • Depuración: Cambiar a un canal de depuración a un usuario específico para diagnosticar problemas

Comparación: Métodos de cambio de canal

MétodoTiempo de efectoPersistido enUso
setChannel() desde pluginInmediatoSolo dispositivo (local)Switch de canal iniciado por el usuario en la aplicación
Ocultar dispositivo en la consolaHasta 2 minBase de datos de backendCambios iniciados por el administrador para dispositivos específicos
API asignación de canalHasta 2 minBase de datos de backendIntegraciones de backend automatizadas

Para obtener la mejor experiencia del usuario al crear interfaces de usuario de cambio de canal, siempre utilice el método del plugin. setChannel() Prácticas recomendadas

Limitar el acceso

  1. : El cambio de canal suele ser para uso interno - no lo exponga a todos los usuariosLimitar el acceso: El cambio de canal suele ser para uso interno - no lo exponga a todos los usuarios
  2. Gestionar Errores: Siempre maneje errores de manera suave cuando se cambian canales
  3. ValidarCompatibilidad: Asegúrese de que las actualizaciones en diferentes canales sean compatibles con la versión nativa instalada
  4. Documentar Canales: Mantenga una documentación clara de qué es cada canal para
  5. Monitorear Uso: Registre qué dispositivos están en qué canales para depuración

Recursos

Conclusión

La navegación entre canales transforma la forma en que puedes iterar en tu aplicación Capacitor. En lugar de tratar los compilados de producción como puntos finales fijos, se convierten en herramientas flexibles para la prueba, la validación y la iteración rápida.

Con la introducción reciente de la navegación instantánea entre canales, la experiencia es ahora ininterrumpida - los usuarios pueden cambiar de canal y recibir actualizaciones inmediatamente del nuevo canal sin ningún período de espera.

Ya sea que estés validando correcciones de errores con partes interesadas, ejecutando programas de beta o depurando problemas con usuarios específicos, la navegación entre canales te da la flexibilidad para enviar la actualización correcta al usuario correcto en el momento correcto.

Sigue adelante desde Navegación entre canales para Capgo: Cómo cambiar los canales de actualización en tiempo de ejecución

Si estás utilizando Navegación entre canales para Capgo: Cómo cambiar los canales de actualización en tiempo de ejecución para planificar la ruta de los canales y la implementación de un despliegue en etapas, conecta con Canales para obtener detalles de implementación en Canales, Canales para los detalles de implementación en Canales, Canales para los detalles de implementación en Canales, Solución de Pruebas Beta para el flujo de trabajo del producto en Solución de Pruebas Beta, y Solución de Alcance de Versión para el flujo de trabajo del producto en Solución de Alcance de Versión.

Actualizaciones en vivo para aplicaciones Capacitor

Cuando haya un error en la capa web, envíe la corrección a través de Capgo en lugar de esperar días para la aprobación de la tienda de aplicaciones. Los usuarios obtienen la actualización en segundo plano mientras los cambios nativos siguen en el camino de revisión normal.

Comienza ahora

Últimas noticias de nuestro Blog

Capgo te da las mejores perspectivas que necesitas para crear una aplicación móvil verdaderamente profesional.