Sandboxes now support real-time filesystem watching via sandbox.watch(). The method returns a Server-Sent Events stream backed by native inotify, so your Worker receives create, modify, delete, and move events as they happen inside the container.
sandbox.watch(path, options)
Pass a directory path and optional filters. The returned stream is a standard ReadableStream you can proxy directly to a browser client or consume server-side.
JavaScript
// Stream events to a browser clientconst stream = await sandbox.watch("/workspace/src", {recursive: true,include: ["*.ts", "*.js"],});return new Response(stream, {headers: { "Content-Type": "text/event-stream" },});TypeScript
// Stream events to a browser clientconst stream = await sandbox.watch("/workspace/src", {recursive: true,include: ["*.ts", "*.js"],});return new Response(stream, {headers: { "Content-Type": "text/event-stream" },});
Server-side consumption with parseSSEStream
Use parseSSEStream to iterate over events inside a Worker without forwarding them to a client.
JavaScript
import { parseSSEStream } from "@cloudflare/sandbox";const stream = await sandbox.watch("/workspace/src", { recursive: true });for await (const event of parseSSEStream(stream)) {console.log(event.type, event.path);}TypeScript
import { parseSSEStream } from "@cloudflare/sandbox";import type { FileWatchSSEEvent } from "@cloudflare/sandbox";const stream = await sandbox.watch("/workspace/src", { recursive: true });for await (const event of parseSSEStream<FileWatchSSEEvent>(stream)) {console.log(event.type, event.path);}
Each event includes a type field (create, modify, delete, or move) and the affected path. Move events also include a from field with the original path.
Options
| Option | Type | Description |
|---|---|---|
recursive | boolean | Watch subdirectories. Defaults to false. |
include | string[] | Glob patterns to filter events. Omit to receive all events. |
Upgrade
To update to the latest version:
npm i @cloudflare/sandbox@latestFor full API details, refer to the Sandbox file watching reference.
Source: Cloudflare
Latest Posts
- Power Platform admin center – Advanced connector policies [MC1403390]
![Power Platform admin center – Advanced connector policies [MC1403390] 2 pexels googledeepmind 17485678](data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==)
- Amazon EC2 M8a instances now available in the Asia Pacific (Mumbai) region

- Amazon RDS Custom now supports the latest CU and GDR updates for Microsoft SQL Server

- Amazon EC2 C7a instances are now available in the Asia Pacific (Singapore) Region


![Power Platform admin center – Advanced connector policies [MC1403390] 2 pexels googledeepmind 17485678](https://mwpro.co.uk/wp-content/uploads/2024/08/pexels-googledeepmind-17485678-150x150.webp)



