如何使用__CAPGO_KEEP_0__的通道进行功能标志和A/B测试
Capgo的通道系统提供了一种灵活的方式来分段用户并控制功能访问。虽然Capgo没有内置的计划管理或A/B测试功能,但您可以通过管理通道分配来实现这些功能。
了解通道
在Capgo中,通道允许您:
- 针对不同用户群组使用不同的功能
- 通过将用户分配到不同的频道来运行A/B测试
- 逐渐推出新功能
- 创建beta测试计划
频道分配方法
1. 后端分配(推荐)
这是更安全的方法。它涉及:
- 从更新器获取设备ID
- 将其发送到您的后端
- 您的后端调用Capgo API来分配设备
以下是如何实现它:
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)
}
后端实现
您的后端需要:
- 从 Capgo 控制台获取一个 API 密钥
- 调用 Capgo API 将设备分配到一个频道
获取您的 API 密钥:
- 登录您的 Capgo 控制台
- 转到设置 > API 密钥
- 点击“生成新密钥”
- 选择
all模式来管理设备和频道 - 复制生成的密钥并在您的后端环境变量中安全存储
- 密钥将是一个 32 个字符的十六进制字符串
- 它是一个秘密密钥,绝不应该在客户端 code 中暴露
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
}
}
后端也应该:
- 验证用户的权限
- 记录所有频道分配
- 处理速率限制
- 为失败的分配实现重试逻辑
2. 自我分配(不安全)
该方法允许设备直接将自己分配到一个频道。它适用于测试,但在生产环境中不安全:
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
}
在 Capgo 控制台中启用此功能之前,用户才能自行分配到频道:
- 在您的 Capgo 控制台中,前往频道部分
- 单击要管理的频道名称
- 在频道设置中,启用“允许设备自行关联”
- 保存更改
如果此设置为 false,任何尝试通过 setChannel 将会失败。
功能标志的实现
使用通道来控制功能访问:
const isFeatureEnabled = async (feature: string) => {
// Example: Check if user is in beta channel
const channel = await getCurrentChannel()
return channel === 'beta'
}
A/B 测试实现
通过将用户分配到不同的通道来运行 A/B 测试:
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
}
最佳实践
- 在生产环境中,始终使用后端分配方法一致的分配
- : 使用用户 ID 或其他稳定的标识符来实现一致的通道分配__CAPGO_KEEP_0__
- 监控: 为每个渠道跟踪功能使用情况和性能指标
- 渐进式发布: 先从小规模用户开始,然后逐渐扩大
- 清晰的文档: 记录您的渠道策略和目的
结论
通过利用Capgo的渠道系统,您可以创建更具个人化的应用体验并进行A/B测试。对于生产环境,始终优先使用后端分配方法以获得更好的安全性和控制。
有关渠道管理的更多详细信息,请参阅我们的 渠道文档.