Advanced Run Job (Enterprise)
Webhooks and the Enterprise routing rule plugin are currently incubating. There may be breaking API changes between releases!
The powerful Enterprise Advanced Run Job webhook handler enables selective execution of one or more jobs based by evaluating event data.
Each event passes through one or more routing rules. If the event satisfies the rule conditions the target job will be executed with the supplied job options. Conditions and job options can be constructed from event data!
General Settings
data:image/s3,"s3://crabby-images/025f0/025f08f7c2cb2a806c01898c36a57c0f9dcefd60" alt=""
Batch Key (optional)
The batch key makes it possible to extract a list from the event and run each item through the rule processing.
Given:
{
"messages": [
{"msg": "foo"},
{"msg": "bar"}
]
}
The batch key $.messages
could be used to process each item
individually.
The batch key supports JsonPath deep scanning. A key
such as $.messages[*].alerts
could be used to extract nested lists
and process the items individually. Lists are recursively flattened.
Event ID Key (optional)
The event ID key can be used to replace the ID auto generated when webhook events are received. This will be reflected in the logs. Batches are extracted before applying the event ID key to each item.
Rules
data:image/s3,"s3://crabby-images/f0eb1/f0eb134161038c848d162e6f4c99815ade6990a5" alt=""
Rules can be individually enabled/disabled!
Each webhook event gets evaluated against each rule. If the rule matches (all conditions are satisfied) the target job will be executed.
Name (optional but srsly)
A label to identify the rule.
Debug
Rule evaluation debug info can be printed to the INFO
log level by selecting the debug option. This can make it easier to troubleshoot rules while reducing noise.
Job
Use the job picker to select a job target. If the rule evaluation is a match the target job will be executed with the Job Options.
Node Filter (optional)
Used to override the job node filter. You can use a JsonPath or Template to craft a node filter from the event data.
User (optional)
Optionally override the user the job runs as. This can be crafted from event data just like Node Filter
Job Options
Job options to be supplied during job execution. Use JsonPath or
Templates to construct the value
from event data.
Conditions
See Conditions
Conditions
data:image/s3,"s3://crabby-images/a7c30/a7c3033e0fdc3f2fb73b7106c784aaa6c67c175e" alt="Oh noes :O"
Policy
- all All conditions must match
- any At least one condition must match
contains
Satisfied if the value at path
contains the provided value
.
dateTimeAfter
dateTimeBefore
Must be a Date with Time.
Compares the parsed Zoned DateTime at path
with the provided DateTime.
Supported formats are:
- ISO_DATE_TIME
- ISO_INSTANT
- Unix EPOCH (assumed to be in milliseconds if year >=2970)
The format in the event need not match the format of the value.
exists
Satisfied if Something exists at the specified path.
matches
Matches is satisfied if the value at path
equals the value of
the provided value
.
isA
Satisfied if the type at path
match a provided value
of:
- string
- number
- map
- list
- null
JsonPath/Templates
Many fields accept a JsonPath or template string. The discriminating criteria are:
- JsonPath: Starts with
$
- Template: Starts with
\$
or/^[^$]/
JsonPath
A JsonPath that selects a data structure(list or map) will return the data structure as serialized JSON.
JsonPath allows for very flexible event data extraction.
See Path Examples in the JsonPath repo for easy examples and inspiration.
Template
In a string template values are substituted with ${}
.
{"foo":"bar"}
Event data can be accessed in ${data}
:
The value is ${data.foo}
-> The value is bar
JsonPath can be used too!:
The value is ${path('$.foo')}
-> The value is bar
FAQ
How do I pass the raw event data to a job?
You can use the JsonPath $.
as a job option value to send the event as a serialized
JSON. You can also send parts of the event by crafting a JsonPath that returns structured
data!