Durable Object Base Class
The DurableObject base class is an abstract class which all Durable Objects inherit from. This base class provides a set of optional methods, frequently referred to as handler methods, which can respond to events, for example a webSocketMessage when using the WebSocket Hibernation API. To provide a concrete example, here is a Durable Object MyDurableObject which extends DurableObject and implements the fetch handler to return "Hello, World!" to the calling Worker.
export class MyDurableObject extends DurableObject {  constructor(ctx, env) {    super(ctx, env);  }
  async fetch(request) {    return new Response("Hello, World!");  }}export class MyDurableObject extends DurableObject {  constructor(ctx: DurableObjectState, env: Env) {    super(ctx, env);  }
  async fetch(request: Request) {    return new Response("Hello, World!");  }}- 
fetch(Request): Response | Promise <Response>- 
Takes an HTTP request object and returns an HTTP response object. This method allows the Durable Object to emulate an HTTP server where a Worker with a binding to that object is the client. 
- 
This method can be async.
 
- 
- 
alarm(: Promise <void>alarmInfoObject)- 
Called by the system when a scheduled alarm time is reached. 
- 
The optional parameter alarmInfoobject has two properties:- retryCountnumber: The number of times this alarm event has been retried.
- isRetryboolean: A boolean value to indicate if the alarm has been retried. This value is- trueif this alarm event is a retry.
 
- 
The alarm()handler has guaranteed at-least-once execution and will be retried upon failure using exponential backoff, starting at two second delays for up to six retries. Retries will be performed if the method fails with an uncaught exception.
- 
This method can be async.
- 
Refer to alarmfor more information.
 
- 
- 
webSocketMessage(ws WebSocket, message string | ArrayBuffer): void- 
Called by the system when an accepted WebSocket receives a message. 
- 
This method can be async.
- 
This method is not called for WebSocket control frames. The system will respond to an incoming WebSocket protocol ping ↗ automatically without interrupting hibernation. 
 
- 
- 
webSocketClose(ws WebSocket, code number, reason string, wasClean boolean): void- 
Called by the system when a WebSocket is closed. wasClean()is true if the connection closed cleanly, false otherwise.
- 
This method can be async.
 
- 
- 
webSocketError(ws WebSocket, error any): void- 
Called by the system when any non-disconnection related errors occur. 
- 
This method can be async.
 
- 
See DurableObjectState documentation.
A list of bindings which are available to the Durable Object.
- Refer to Use WebSockets for more information on examples of WebSocket methods and best practices.
Was this helpful?
- Resources
- API
- New to Cloudflare?
- Products
- Sponsorships
- Open Source
- Support
- Help Center
- System Status
- Compliance
- GDPR
- Company
- cloudflare.com
- Our team
- Careers
- © 2025 Cloudflare, Inc.
- Privacy Policy
- Terms of Use
- Report Security Issues
- Trademark