DurableObjectNamespace
A Durable Object Namespace represents a globally unique namespace for Durable Objects that provide strongly consistent storage and coordination.
Minimal Example
Section titled “Minimal Example”Create a basic Durable Object namespace for stateful chat rooms.
import { DurableObjectNamespace } from "alchemy/cloudflare";
const rooms = DurableObjectNamespace("chat-rooms", {  className: "ChatRoom",});Create with SQLite Storage
Section titled “Create with SQLite Storage”Create a Durable Object with SQLite storage for user data.
import { DurableObjectNamespace } from "alchemy/cloudflare";
const users = DurableObjectNamespace("user-store", {  className: "User",  sqlite: true,});Create in Production Environment
Section titled “Create in Production Environment”Create a Durable Object in production for game state management.
import { DurableObjectNamespace } from "alchemy/cloudflare";
const game = DurableObjectNamespace("game-state", {  className: "GameState",  scriptName: "game-worker",  environment: "production",});Bind to a Worker
Section titled “Bind to a Worker”Bind a Durable Object namespace to a Worker to enable access.
import { Worker, DurableObjectNamespace } from "alchemy/cloudflare";
const counter = DurableObjectNamespace("counter", {  className: "Counter",});
await Worker("my-worker", {  name: "my-worker",  script: "console.log('Hello, world!')",  bindings: {    COUNTER: counter,  },});Rename Class Name
Section titled “Rename Class Name”Alchemy takes care of migrations automatically when you rename the class name.
import { DurableObjectNamespace } from "alchemy/cloudflare";
const counter = DurableObjectNamespace("counter", {  className: "Counter",  className: "MyCounter",  sqlite: true,});Cross-Script Binding
Section titled “Cross-Script Binding”You can share Durable Objects across multiple Workers, allowing one Worker to access Durable Object instances defined in another Worker.
Method 1: Using re-exported syntax
Section titled “Method 1: Using re-exported syntax”You can directly reference the Durable Object binding from the provider Worker:
import { Worker, DurableObjectNamespace } from "alchemy/cloudflare";
// Create the provider Worker with the Durable Objectconst host = await Worker("Host", {  entrypoint: "./do-provider.ts",  bindings: {    SHARED_COUNTER: DurableObjectNamespace("shared-counter", {      className: "SharedCounter",      sqlite: true,    }),  },});
// Create the client Worker using the provider's Durable Object binding directlyconst client = await Worker("client", {  entrypoint: "./client-worker.ts",  bindings: {    // Re-use the exact same Durable Object binding from the provider worker    SHARED_COUNTER: host.bindings.SHARED_COUNTER,  },});Method 2: Using scriptName directly
Section titled “Method 2: Using scriptName directly”Alternatively, when creating a Durable Object binding in a client Worker, you can reference a Durable Object defined in another Worker by specifying the scriptName:
import { Worker, DurableObjectNamespace } from "alchemy/cloudflare";
const hostWorkerName = "host";
const durableObject = DurableObjectNamespace("shared-counter", {  className: "SharedCounter",  scriptName: hostWorkerName,  sqlite: true,});
// First, create the Worker that defines the Durable Objectconst host = await Worker("host", {  entrypoint: "./do-provider.ts",  name: hostWorkerName,  bindings: {    // Define the Durable Object in this worker    SHARED_COUNTER: durableObject,  },});
// Then, create a client Worker that uses the cross-script Durable Objectconst client = await Worker("client", {  entrypoint: "./client-worker.ts",  bindings: {    // Reference the same Durable Object but specify which script it comes from    SHARED_COUNTER: durableObject,  },});