Skip to content

A API WebSocket do lado do servidor do Bun fornece uma API nativa pub-sub. Os sockets podem ser inscritos em um conjunto de canais nomeados usando socket.subscribe(<name>); mensagens podem ser publicadas em um canal usando socket.publish(<name>, <message>).

Este trecho de código implementa um servidor de chat simples de canal único.

ts
const server = Bun.serve({
  fetch(req, server) {
    const cookies = req.headers.get("cookie");
    const username = getUsernameFromCookies(cookies);
    const success = server.upgrade(req, { data: { username } });
    if (success) return undefined;

    return new Response("Hello world");
  },
  websocket: {
    // TypeScript: especifique o tipo de ws.data assim
    data: {} as { username: string },

    open(ws) {
      const msg = `${ws.data.username} entrou no chat`;
      ws.subscribe("the-group-chat");
      server.publish("the-group-chat", msg);
    },
    message(ws, message) {
      // o servidor retransmite mensagens recebidas para todos
      server.publish("the-group-chat", `${ws.data.username}: ${message}`);
    },
    close(ws) {
      const msg = `${ws.data.username} saiu do chat`;
      server.publish("the-group-chat", msg);
      ws.unsubscribe("the-group-chat");
    },
  },
});

console.log(`Ouvindo em ${server.hostname}:${server.port}`);

Bun by www.bunjs.com.cn edit