Come utilizzare i canali per le bandiere di feature e il testing A/B
Il sistema dei canali di Capgo offre una soluzione flessibile per segmentare gli utenti e controllare l'accesso alle feature. Sebbene Capgo non disponga di una gestione di piani o di testing A/B integrata, puoi implementare queste funzionalità gestendo le assegnazioni dei canali in modo autonomo.
Capire i canali
I canali di Capgo ti consentono di:
- Targetare gruppi di utenti specifici con feature diverse
- Esegui test A/B assegnando gli utenti a canali diversi
- Lancia progressivamente nuove funzionalità
- Crea programmi di testing beta
Metodi di assegnazione dei canali
1. Assegnazione backend (Consigliato)
Questo è il metodo più sicuro. Prevede:
- Ottenere l'ID dispositivo dal updater
- Inviarlo al tuo backend
- Il tuo backend chiama il Capgo API per assegnare il dispositivo
Ecco come 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)
}
Implementazione backend
Il tuo backend deve:
- Ottenere una chiave API dal dashboard Capgo
- Chiamare il Capgo API per assegnare il dispositivo a un canale
Per ottenere la tua chiave API:
- Accedi al tuo dashboard Capgo
- Vai a Impostazioni > Chiavi API
- Clicca su “Genera Chiave Nuova”
- Seleziona
allmodalità per gestire dispositivi e canali - Copia la chiave generata e memorizzala in modo sicuro nelle tue variabili di ambiente backend
- La chiave sarà una stringa esadecimale di 32 caratteri
- È una chiave segreta che non dovrebbe mai essere esposta nel code client-side
Ecco un esempio di 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
}
}
Il backend dovrebbe anche:
- Verificare le autorizzazioni dell'utente
- Registrare tutte le assegnazioni di canale
- Gestire il limitatore di velocità
- Implementare la logica di riprova per le assegnazioni fallite
2. Auto-assegnazione (Meno Sicura)
Questo metodo consente ai dispositivi di assegnarsi direttamente a un canale. È utile per i test ma meno sicuro per la produzione:
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
}
Prima che gli utenti possano auto-assegnarsi a un canale, è necessario abilitare questa funzionalità nel Capgo dashboard:
- Vai alla sezione Canali del tuo Capgo dashboard
- Clicca sul nome del canale che desideri gestire
- Nelle impostazioni del canale, abilita "Consenti ai dispositivi di auto-associarsi"
- Salva le modifiche
Se questo impostazione è falsa, qualsiasi tentativo di chiamata setChannel con questo canale fallirà.
Implementazione delle Bandiere di Feature
Utilizza i canali per controllare l'accesso alle feature:
const isFeatureEnabled = async (feature: string) => {
// Example: Check if user is in beta channel
const channel = await getCurrentChannel()
return channel === 'beta'
}
Implementazione di Test A/B
Esegui test A/B assegnando gli utenti a diversi canali:
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
}
Pratiche Consigliate
- Utilizza l'assegnazione di backend:Per la produzione, utilizza sempre il metodo di assegnazione di backend:
- Assegnazione Consistente:Utilizza gli ID degli utenti o altri identificatori stabili per un'assegnazione di canale coerente:
- Monitoraggio: Tracciare l'utilizzo delle funzionalità e i metrici di prestazione per ogni canale
- Graduali Rilasci: Iniziare con piccoli segmenti di utenti e espandere gradualmente
- Documentazione Chiara: Documentare la strategia e le finalità del proprio canale
Conclusioni
Sfruttando il sistema dei canali di Capgo è possibile creare esperienze di app più personalizzate e condurre test A/B. Per l'utilizzo in produzione, preferire sempre il metodo di assegnazione backend per una maggiore sicurezza e controllo.
Per ulteriori informazioni sulla gestione dei canali, consultare la nostra documentazione sui canali.