Pular para o conteúdo principal

Documentation Index

Fetch the complete documentation index at: https://docs.squarecloud.app/llms.txt

Use this file to discover all available pages before exploring further.

app.realtime() abre um stream Server-Sent Events e retorna a Response bruta. O SDK não faz parsing dos frames SSE — ele entrega o stream para que você integre no seu próprio loop de eventos.

Limites de conexão

  • Cada conexão dura até 10 minutos, depois o servidor a encerra
  • Uma única conta mantém no máximo 10 conexões simultâneas

Formato dos eventos

O stream emite dois tipos de frames:
  • event: system — mensagens de ciclo de vida da conexão, como REALTIME_CONNECTING, REALTIME_TIMEOUT, etc.
  • event: message — payload JSON da aplicação

Consumindo o stream

import { SquareCloudAPI } from "@squarecloud/api";

const api = new SquareCloudAPI(process.env.SQUARE_API_KEY!);
const app = await api.applications.fetch("abc123def456abc123def456");

const response = await app.realtime();

if (!response.body) {
    throw new Error("Stream sem body");
}

const reader = response.body.pipeThrough(new TextDecoderStream()).getReader();
let buffer = "";

while (true) {
    const { value, done } = await reader.read();
    if (done) break;

    buffer += value;

    // Frames SSE são separados por \n\n
    let separator = buffer.indexOf("\n\n");
    while (separator !== -1) {
        const rawFrame = buffer.slice(0, separator);
        buffer = buffer.slice(separator + 2);
        separator = buffer.indexOf("\n\n");

        const event = parseSSE(rawFrame);
        if (!event) continue;

        if (event.name === "system") {
            console.log(`[system] ${event.data}`);
            continue;
        }

        try {
            const payload = JSON.parse(event.data);
            console.log("[message]", payload);
        } catch {
            console.log("[message]", event.data);
        }
    }
}

function parseSSE(frame: string): { name: string; data: string } | null {
    let name = "message";
    let data = "";

    for (const line of frame.split("\n")) {
        if (line.startsWith("event:")) name = line.slice(6).trim();
        else if (line.startsWith("data:")) data += line.slice(5).trim();
    }

    return data ? { name, data } : null;
}
Cada chamada a app.realtime() retorna uma Response nova. Para se manter conectado além do timeout de 10 minutos do servidor, reconecte quando o stream encerrar.