Files
bun.sh/docs/guides/websocket/simple.mdx
2025-11-05 11:14:21 -08:00

36 lines
949 B
Plaintext

---
title: Build a simple WebSocket server
sidebarTitle: Simple server
mode: center
---
Start a simple WebSocket server using [`Bun.serve`](https://bun.com/docs/api/http).
Inside `fetch`, we attempt to upgrade incoming `ws:` or `wss:` requests to WebSocket connections.
```ts server.ts icon="/icons/typescript.svg"
const server = Bun.serve<{ authToken: string }>({
fetch(req, server) {
const success = server.upgrade(req);
if (success) {
// Bun automatically returns a 101 Switching Protocols
// if the upgrade succeeds
return undefined;
}
// handle HTTP request normally
return new Response("Hello world!");
},
websocket: {
// this is called when a message is received
async message(ws, message) {
console.log(`Received ${message}`);
// send back a message
ws.send(`You said: ${message}`);
},
},
});
console.log(`Listening on ${server.hostname}:${server.port}`);
```