Schedule tasks
An Agent can schedule tasks to be run in the future by calling this.schedule(when, callback, data), where when can be a delay, a Date, or a cron string; callback the function name to call, and data is an object of data to pass to the function.
Scheduled tasks can do anything a request or message from a user can: make requests, query databases, send emails, read+write state: scheduled tasks can invoke any regular method on your Agent.
You can call this.schedule within any method on an Agent, and schedule tens-of-thousands of tasks per individual Agent:
import { Agent } from "agents";
export class SchedulingAgent extends Agent {  async onRequest(request) {    // Handle an incoming request    // Schedule a task 10 minutes from now    // Calls the "checkFlights" method    let { taskId } = await this.schedule(600, "checkFlights", {      flight: "DL264",      date: "2025-02-23",    });    return Response.json({ taskId });  }
  async checkFlights(data) {    // Invoked when our scheduled task runs    // We can also call this.schedule here to schedule another task  }}import { Agent } from "agents"
export class SchedulingAgent extends Agent {  async onRequest(request) {    // Handle an incoming request    // Schedule a task 10 minutes from now    // Calls the "checkFlights" method    let { taskId } = await this.schedule(600, "checkFlights", { flight: "DL264", date: "2025-02-23" });    return Response.json({ taskId });  }
  async checkFlights(data) {    // Invoked when our scheduled task runs    // We can also call this.schedule here to schedule another task  }}You can schedule tasks in multiple ways:
// schedule a task to run in 10 secondslet task = await this.schedule(10, "someTask", { message: "hello" });
// schedule a task to run at a specific datelet task = await this.schedule(new Date("2025-01-01"), "someTask", {});
// schedule a task to run every 10 minuteslet { id } = await this.schedule("*/10 * * * *", "someTask", {  message: "hello",});
// schedule a task to run every 10 minutes, but only on Mondayslet task = await this.schedule("*/10 * * * 1", "someTask", {  message: "hello",});
// cancel a scheduled taskthis.cancelSchedule(task.id);// schedule a task to run in 10 secondslet task = await this.schedule(10, "someTask", { message: "hello" });
// schedule a task to run at a specific datelet task = await this.schedule(new Date("2025-01-01"), "someTask", {});
// schedule a task to run every 10 minuteslet { id } = await this.schedule("*/10 * * * *", "someTask", { message: "hello" });
// schedule a task to run every 10 minutes, but only on Mondayslet task = await this.schedule("*/10 * * * 1", "someTask", { message: "hello" });
// cancel a scheduled taskthis.cancelSchedule(task.id);Calling await this.schedule returns a Schedule, which includes the task's randomly generated id. You can use this id to retrieve or cancel the task in the future. It also provides a type property that indicates the type of schedule, for example, one of "scheduled" | "delayed" | "cron".
You can get, cancel and filter across scheduled tasks within an Agent using the scheduling API:
// Get a specific schedule by ID// Returns undefined if the task does not existlet task = await this.getSchedule(task.id);
// Get all scheduled tasks// Returns an array of Schedule objectslet tasks = this.getSchedules();
// Cancel a task by its ID// Returns true if the task was cancelled, false if it did not existawait this.cancelSchedule(task.id);
// Filter for specific tasks// e.g. all tasks starting in the next hourlet tasks = this.getSchedules({  timeRange: {    start: new Date(Date.now()),    end: new Date(Date.now() + 60 * 60 * 1000),  },});// Get a specific schedule by ID// Returns undefined if the task does not existlet task = await this.getSchedule(task.id)
// Get all scheduled tasks// Returns an array of Schedule objectslet tasks = this.getSchedules();
// Cancel a task by its ID// Returns true if the task was cancelled, false if it did not existawait this.cancelSchedule(task.id);
// Filter for specific tasks// e.g. all tasks starting in the next hourlet tasks = this.getSchedules({  timeRange: {    start: new Date(Date.now()),    end: new Date(Date.now() + 60 * 60 * 1000),  }});Was this helpful?
- Resources
- API
- New to Cloudflare?
- Directory
- 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