Introducción
Cuando comiences a disfrutar del sistema de actualización de Capgo, como yo con mis aplicaciones, comenzarás a sentir el sentimiento “¿Qué si quiero más?”
También lo sentí, pero como soy el creador de Capgo, pude echar un vistazo!
Dado que todo es de código abierto, también tienes este poder :)
La siguiente molestia que obtuve en el proceso de distribución de aplicaciones de Capacitor es hacer que otros compañeros de equipo prueben las actualizaciones!
Con TestFlight, el problema es simple, pero llevar a personas a tu equipo y hacer que entiendan cómo obtenerlo es un proceso que consume tiempo!
Y por supuesto, cada vez que envíes a Apple tienes un proceso de revisión aleatorio por un bot que puede tomar 5 minutos o 5 horas, nunca sabes.
Me retrasé muchas veces mi presentación debido a esto…
Y para Google esto es incluso peor, el gran misterio de mi vida, lanzar una versión de producción toma menos de 2 horas, pero lanzar una beta cerrada toma 1–2 días.
Solución
Para solucionar esto, creé el sistema de canales en Capgo.
npx @capgo/cli@latest bundle upload -c production actualizará a todos los usuarios (si el canal de producción está configurado como predeterminado)
If you do, then the version lands to a different channel, this can be automatized in __CAPGO_KEEP_0__ action npx @capgo/cli@latest bundle upload -c development Then you have 2 ways to let users get the updates from the channel GitHub action.
This can be useful when you don’t want to create your own backend for channel set, this is fast to implement.
With that one, the only thing you need to do is allow one of your channels to be self to set.
Allow set self in __CAPGO_KEEP_0__
And then add this in the __CAPGO_KEEP_0__ of your Ionic app, for best experience, use this after the user clicks on a button like “register for beta”

And then add this in the code of your Ionic app, for best experience, use this after the user clicks on a button like “register for beta”
import { CapacitorUpdater } from '@capgo/capacitor-updater'
const deviceId = await CapacitorUpdater.setChannel({ channel: 'beta' })
Allow users to copy their deviceID from your app and send it to you manually, this __CAPGO_KEEP_0__ will help you to get it:
This can be useful for your internal team, this is fast to implement. Allow users to copy their deviceID from your app and send it to you manually, this code will help you to get it:
import { CapacitorUpdater } from '@capgo/capacitor-updater'
const deviceId = await CapacitorUpdater.getDeviceId()
Si haces esto, entonces la versión se desplaza a un canal diferente, esto se puede automatizar en __CAPGO_KEEP_0__ acción admin por ejemplo, el rol.
Vaya a la aplicación web o nativa Capgo, conecte como administrador de la aplicación, seleccione su aplicación, haga clic en la lista de dispositivos.
Coloque en la barra de búsqueda el ID del dispositivo, haga clic en el encontrado y luego haga clic en el enlace de Canal, elija el development, pida a su compañero de equipo que abra la aplicación nuevamente, espere 30 segundos y abra/cierre.
Debería obtener la versión de usted.
Forma automática
Esta puede ser útil para sus pruebas beta, esta es más larga de implementar.
Lo mismo que la forma manual, debe obtener el ID del dispositivo
import { CapacitorUpdater } from '@capgo/capacitor-updater'
const deviceId = await CapacitorUpdater.getDeviceId()
Pero esta vez debe enviarlo automáticamente a su backend, le dejo que decida cómo lo hace.
Sólo le sugiero que lo almacene en una base de datos, que facilitará su vida más adelante.
Luego en su backend debe enviarlo a Capgo backend también. A continuación, dos code ejemplos:
NodeJS
import axios from 'axios'
await axios.post('https://api.capgo.app/device', {
app_id: 'YOUR_APP_ID',
device_id: 'DEVICE_ID',
channel: 'CHANNEL_NAME', // The name of the channel, or undefined if version_id provided
version_id: 'VERSION_NAME' // this is optional, if provide it will override the channel, that useful when you want to debug only one user.
}, {
headers: {
authorization: 'YOUR_API_KEY' // choose a key with 'write' or 'all' rights
}
})
Cloudflare
addEventListener('fetch', (event) => {
event.respondWith(
handleRequest(event.request).catch(
err => new Response(err.stack, { status: 500 })
)
)
})
async function handleRequest(request) {
const { pathname, method } = new URL(request.url)
const body = await request.json()
const newBody = JSON.stringify({
app_id: 'YOUR_APP_ID',
device_id: body.device_id,
channel: 'alpha'
})
const newUrl = new URL('https://api.capgo.app/device')
const options = {
headers: {
authorization: 'YOUR_API_KEY',
},
method: 'POST',
body: newBody
}
if (request.method === 'DELETE') {
// DELETE the channel link
options.method = 'DELETE'
return fetch(newUrl.toString(), options)
}
return fetch(newUrl.toString(), options)
}
Y simplemente envía tu dispositivo_id en el cuerpo de ella a la URL desplegada con POST para agregar y el método DELETE para eliminar.
Después de esta configuración, intenta agregar un botón en tu aplicación para optar a la canal, y verifica en la aplicación web si eso se ha establecido.
También puedes enviar null para eliminar la sobrescritura
Si necesitas verificar programáticamente qué sobrescritura está configurada en un dispositivo, puedes obtener en la misma URL
import axios from 'axios'
const res = await axios.get('https://api.capgo.app/device?app_id=YOUR_APP_ID&device_id=DEVICE_ID', {
headers: {
authorization: 'YOUR_API_KEY' // choose a key with 'write' or 'all' rights
}
})
console.log('data', res.json())
Sigue adelante desde Cómo enviar una actualización específica a un usuario o un grupo
Si estás utilizando Cómo enviar una actualización específica a un usuario o un grupo para planificar la ruta de canalización y el despliegue en etapas, conecta con Canal para los detalles de implementación en Canal, 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 Enfoque en Versión para el flujo de trabajo del producto en Solución de Enfoque en Versión.