Sending events from functions step.sendEvent()
Use to send event(s) reliability within your function. Use this instead of inngest.send()
to ensure reliable event delivery from within functions. This is especially useful when creating functions that fan-out.
export default inngest.createFunction(
{ id: "user-onboarding" },
{ event: "app/user.signup" },
async ({ event, step }) => {
// Do something
await step.sendEvent("send-activation-event", {
name: "app/user.activated",
data: { userId: event.data.userId },
});
// Do something else
}
);
To send events from outside of the context of a function, use inngest.send()
.
step.sendEvent(id, eventPayload | eventPayload[]): Promise
- Name
id
- Type
- string
- Required
- required
- Description
The ID of the step. This will be what appears in your function's logs and is used to memoize step state across function versions.
- Name
eventPayload
- Type
- object | object[]
- Required
- required
- Description
An event payload object or an array of event payload objects.
See the documentation for
inngest.send()
for the event payload format.
// Send a single event
await step.sendEvent("send-activation-event", {
name: "app/user.activated",
data: { userId: "01H08SEAXBJFJNGTTZ5TAWB0BD" },
});
// Send an array of events
await step.sendEvent("send-invoice-events", [
{
name: "app/invoice.created",
data: { invoiceId: "645e9e024befa68763f5b500" },
},
{
name: "app/invoice.created",
data: { invoiceId: "645e9e08f29fb563c972b1f7" },
},
]);
step.sendEvent()
must be called using await
or some other Promise handler to ensure your function sleeps correctly.