|
1 år sedan | |
---|---|---|
.. | ||
README.md | 1 år sedan |
A scheduled job is a function executed at a specified interval of time in the background of your Medusa application.
A scheduled job is created in a TypeScript or JavaScript file under the src/jobs
directory.
For example, create the file src/jobs/hello-world.ts
with the following content:
import {
IProductModuleService,
MedusaContainer
} from "@medusajs/framework/types";
import { Modules } from "@medusajs/framework/utils";
export default async function myCustomJob(container: MedusaContainer) {
const productService: IProductModuleService = container.resolve(Modules.PRODUCT)
const products = await productService.listAndCountProducts();
// Do something with the products
}
export const config = {
name: "daily-product-report",
schedule: "0 0 * * *", // Every day at midnight
};
A scheduled job file must export:
name
: a unique name for the job.schedule
: a cron expression.numberOfExecutions
: an optional integer, specifying how many times the job will execute before being removedThe handler
is a function that accepts one parameter, container
, which is a MedusaContainer
instance used to resolve services.