Creating workflow actions
The @inngest/workflow-kit package provides a workflow engine, enabling you to create workflow actions on the back end. These actions are later provided to the front end so end-users can build their own workflow instance using the <Editor />.
Workflow actions are defined as two objects using the EngineAction (for the back-end) and PublicEngineAction (for the front-end) types.
import { type PublicEngineAction } from "@inngest/workflow";
export const actionsDefinition: PublicEngineAction[] = [
{
kind: "grammar_review",
name: "Perform a grammar review",
description: "Use OpenAI for grammar fixes",
},
];
In the example above, the actionsDefinition array would be passed via props to the <Provider /> while the actions are passed to the Engine.
Why do I need two types of actions?
The actions need to be separated into 2 distinct objects to avoid leaking the action handler implementations and dependencies into the front end:
Passing actions to the React components: PublicEngineAction[]
- Name
kind- Type
- string
- Required
- required
- Description
Kind is an enum representing the action's ID. This is not named as "id" so that we can keep consistency with the WorkflowAction type.
- Name
name- Type
- string
- Required
- required
- Description
Name is the human-readable name of the action.
- Name
description- Type
- string
- Required
- optional
- Description
Description is a short description of the action.
- Name
icon- Type
- string
- Required
- optional
- Description
Icon is the name of the icon to use for the action. This may be an URL, or an SVG directly.
Passing actions to the Workflow Engine: EngineAction[]
Note: Inherits PublicEngineAction properties.
- Name
handler- Type
- function
- Required
- optional
- Description
The handler is your code that runs whenever the action occurs. Every function handler receives a single object argument which can be deconstructed. The key arguments are
eventandstep.
src/inngest/actions.ts
import { type EngineAction } from "@inngest/workflow";
import { actionsDefinition } from "./actions-definition";
export const actions: EngineAction[] = [
{
// Add a Table of Contents
...actionsDefinition[0],
handler: async ({ event, step, workflow, workflowAction, state }) => {
// ...
}
},
];
The details of the handler() unique argument's properties can be found below:
handler() function argument properties
- Name
event- Type
- TriggerEvent
- Required
- optional
- Description
See the Inngest Function handler
eventargument property definition.
- Name
step- Type
- Step
- Required
- optional
- Description
See the Inngest Function handler
stepargument property definition.
- Name
workflow- Type
- Workflow
- Required
- optional
- Description
See the Workflow instance format.
- Name
workflowAction- Type
- WorkflowAction
- Required
- optional
- Description
WorkflowAction is the action being executed, with fully interpolated inputs.
Key properties are:
id: string: The ID of the action within the workflow instance.kind: string: The action kind, as provided in thePublicEngineAction.name?: string: The name, as provided in thePublicEngineAction.description?: string: The description, as provided in thePublicEngineAction.inputs?: string: The record key is the key of the EngineAction input name, and the value is the variable's value.
- Name
state- Type
- object
- Required
- optional
- Description
State represents the current state of the workflow, with previous action's outputs recorded as key-value pairs.