Habilitar sesión externa
Cómo usar el broker como habilitador para arrancar tu propia sesión dentro del iframe sin exponer secretos en la URL.
Flujo
Iframe
<!doctype html>
<html>
<body>
<div id="app">Iniciando…</div>
<script>
const TRUSTED = ['https://console.videsk.io', 'https://app.videsk.io'];
async function bootstrap(context) {
// 1. Pide a TU backend un token de sesión a partir del id del agente
// y la llamada. Tu backend decide si confía en esta solicitud
// (por ejemplo, validando el dominio de origen, IP, etc.).
const res = await fetch('https://api.tu-app.com/sessions', {
method: 'POST',
headers: { 'Content-Type': 'application/json' },
body: JSON.stringify({
agentEmail: context.user?.email,
callId: context.call?.id,
}),
});
const { sessionToken } = await res.json();
// 2. A partir de aquí tu app vive sola.
renderTickets(sessionToken, context.call?.id);
}
async function renderTickets(token, callId) {
const res = await fetch(`https://api.tu-app.com/tickets?call=${callId}`, {
headers: { Authorization: `Bearer ${token}` },
});
const tickets = await res.json();
document.getElementById('app').textContent =
`Tickets: ${tickets.length}`;
}
window.addEventListener('message', (event) => {
if (!TRUSTED.includes(event.origin)) return;
if (event.data?.type !== 'videsk:init') return;
bootstrap(event.data.context);
});
window.parent.postMessage({ type: 'videsk:ready' }, '*');
</script>
</body>
</html>Configuración
Alternativa: token en la URL
Última actualización
¿Te fue útil?

