Skip to main content
Version: v2 ⚡

Converting Triggers from v1 to v2

In this article we provide an overview of how to migrate your Triggers from OpenFn v1 to v2.

Converting Triggers

Trigger Types on v1

We use 4 types of triggers on v1: Message Filters, Cron Triggers, Flow Triggers, and Fail Triggers.

Converting Cron Triggers

Setting up a Cron Trigger on v2 works just the same as on v1: when you're building a Workflow, select Cron Schedule as Trigger type, and set the frequency.

Converting Flow and Fail Triggers

With a Flow trigger, we can execute a job upon success of another specified job. With a Fail trigger, the job will run if an another specified job failed.

On v2, we achieve the same conditional behavior with Path Conditions: a job can run (1) always, (2), on success of another job, (3) on failure of another job, or (4) on a custom condition - we'll get to this last one in the next section.

So, if on v1 you had a Flow Trigger, on v2 you'll need to choose the On Success condition between your jobs. If you had a Fail Trigger, select the On Failure condition.

Converting Message Filters

V1 Message Filters work with webhooks: if an external application sends data to your project, you can check whether the incoming message meets (or doesn't meet) certain criteria, and execute jobs accordingly.

V2 works on the same principle, with a somewhat different setup.

One Webhook per Workflow

On V1, you had one unified Inbox for your entire project, where all messages would arrive to the same shared webhook URL from every source application. These were then picked up by the different jobs based on Message Filter Triggers.

Unified Inbox

The main difference on V2 is that each workflow that operates with a webhook trigger has its own unique webhook URL to receive data to.

V2 Webhook Trigger

This will mean that in your source applications you will probably need to configure multiple webhooks/forwarders, one for each of your recieving workflows, instead of the previous common Inbox one.

Path Conditions

Once you've configured your Webhook, you can use a custom Path Condition that matches a JavaScript expression to decide whether a subsequent job should be executed or not.

For example, if on v1 you had a Message Filter trigger that looked like this:

Trigger Example

The matching v2 JavaScript Path Condition would look like this:

Path Condition Example