Pulsa para ir al contenido principal
Tutoriales

Cómo utilizar canales para banderas de características y pruebas A/B

Aprende a utilizar los canales de Capgo para banderas de características y pruebas A/B asignando usuarios de forma autónoma o utilizando tu backend

Martin Donadieu

Martin Donadieu

Gerente de Contenido

Cómo utilizar canales para banderas de características y pruebas A/B

How to Use Channels for Feature Flags and A/B Testing

Capgo’s canal de sistema proporciona una forma flexible para segmentar a los usuarios y controlar el acceso a las características. Si bien Capgo no tiene gestión de planes integrada ni pruebas A/B, puede implementar estas características gestionando las asignaciones de canales usted mismo.

Entendiendo los Canales

Los canales en Capgo te permiten:

  • Dirigir grupos de usuarios específicos con características diferentes
  • Ejecutar pruebas A/B asignando a los usuarios a diferentes canales
  • Implementar la entrega gradual de nuevas características
  • Crear programas de pruebas beta

Métodos de Asignación de Canales

Este es el método más seguro. Implica:

  1. Obtener el ID del dispositivo desde el actualizador
  2. Enviarla a tu backend
  3. Tu backend llama al Capgo API para asignar el dispositivo

Aquí está cómo implementarlo:

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

// Get device ID
const getDeviceId = async () => {
  const { deviceId } = await CapacitorUpdater.getDeviceId()
  return deviceId
}

// Send device ID to your backend
const assignToChannel = async (channel: string) => {
  const deviceId = await getDeviceId()
  // Your backend will call Capgo API to assign the device
  await yourBackend.assignDeviceToChannel(deviceId, channel)
}

Implementación de Backend

Tu backend necesita:

  1. Obtener una clave API desde la consola de Capgo
  2. Llamar al Capgo API para asignar el dispositivo a un canal

Para obtener tu clave API:

  1. Inicia sesión en tu consola de Capgo
  2. Ve a Configuración > Claves API
  3. Haz clic en “Generar Nueva Clave”
  4. Selecciona all modo para gestionar dispositivos y canales
  5. Copie la clave generada y almacénela de manera segura en sus variables de entorno de backend
    • La clave será una cadena hexadecimal de 32 caracteres
    • Es una clave secreta que nunca debe ser expuesta en el lado del cliente code

Aquí hay un ejemplo de Node.js:

import axios from 'axios'

const CAPGO_API_KEY = 'your_api_key'
const CAPGO_API_URL = 'https://api.capgo.app'

async function assignDeviceToChannel(deviceId: string, channel: string) {
  try {
    const response = await axios.post(
      `${CAPGO_API_URL}/device`,
      {
        app_id: 'YOUR_APP_ID',
        device_id: deviceId,
        channel: channel
      },
      {
        headers: {
          'authorization': CAPGO_API_KEY,
          'Content-Type': 'application/json'
        }
      }
    )
    return response.data
  } catch (error) {
    console.error('Failed to assign device to channel:', error)
    throw error
  }
}

El backend también debe:

  • Validar las permisos del usuario
  • Registrar todas las asignaciones de canales
  • Gestionar el límite de velocidad
  • Implementar la lógica de reintento para las asignaciones fallidas

2. Autoasignación (Menos Seguro)

Este método permite que los dispositivos se asignen directamente a un canal. Es útil para pruebas pero menos seguro para la producción:

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

// Assign device to channel
const assignToChannel = async (channel: string) => {
  await CapacitorUpdater.setChannel(channel)
}

// Get current channel
const getCurrentChannel = async () => {
  const { channel } = await CapacitorUpdater.getChannel()
  return channel
}

Antes de que los usuarios puedan asignarse a un canal, debe habilitar esta función en el panel de control Capgo:

  1. Vaya a la sección de canales en su panel de control Capgo
  2. Haga clic en el nombre del canal que desea gestionar
  3. En la configuración del canal, habilite “Permitir que los dispositivos se asocie automáticamente”
  4. Guarde los cambios

Si esta configuración es falsa, cualquier intento de llamar setChannel Implementación de Marcadores de Características

Use canales para controlar el acceso a las características:

Implementación de Pruebas A/B

const isFeatureEnabled = async (feature: string) => {
  // Example: Check if user is in beta channel
  const channel = await getCurrentChannel()
  return channel === 'beta'
}

Ejecutar pruebas A/B asignando a los usuarios a diferentes canales:

Consejos para un buen uso

const assignToABTest = async (userId: string) => {
  // Use consistent hashing to assign users
  const hash = await hashUserId(userId)
  const variant = hash % 2 === 0 ? 'variant-a' : 'variant-b'
  
  await assignToChannel(variant)
  return variant
}

Prácticas recomendadas

  1. Uso de Asignación de Backend: Para producción, siempre utilice el método de asignación de backend
  2. Asignación Consistente: Utilice IDs de usuarios o otros identificadores estables para una asignación de canal consistente
  3. Monitoreo: Registre el uso de características y métricas de rendimiento para cada canal
  4. Despliegues Graduales: Comience con segmentos de usuarios pequeños y amplíe gradualmente
  5. Documentación Clara: Documente su estrategia de canales y propósitos

Conclusión

Al aprovechar el sistema de canales de Capgo puede crear experiencias de aplicación más personalizadas y realizar pruebas A/B. Para el uso en producción, siempre prefiera el método de asignación de backend por una mayor seguridad y control.

Para obtener más detalles sobre la gestión de canales, consulte nuestra documentación de canales.

Siga adelante desde Cómo usar canales para banderas de características y pruebas A/B

Si está utilizando Cómo usar canales para banderas de características y pruebas A/B para planificar la ruta de los canales y la implementación escalonada, conéctelo con Canales para obtener detalles de implementación en Canales, Canales para obtener detalles de implementación en Canales, Canales para obtener 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 Enfoque de Versión para el flujo de trabajo del producto en Solución de Enfoque de Versión.

Actualizaciones en vivo para aplicaciones Capacitor

Cuando un error en la capa de web está en vivo, envía 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 reciben la actualización en segundo plano mientras los cambios nativos siguen en el camino de revisión normal.

Inicia Ahora

Últimas noticias de nuestro Blog

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