2019-09-10 13:32:51 -04:00
|
|
|
[role="xpack"]
|
2017-03-28 17:23:01 -04:00
|
|
|
[[condition-array-compare]]
|
2020-12-08 16:33:10 -05:00
|
|
|
=== {watcher} array compare condition
|
|
|
|
++++
|
|
|
|
<titleabbrev>Array compare condition</titleabbrev>
|
|
|
|
++++
|
2017-03-28 17:23:01 -04:00
|
|
|
|
|
|
|
Use `array_compare` to compare an array of values in the execution context to a
|
2019-09-30 13:18:50 -04:00
|
|
|
given value. See <<condition-compare-operators>>
|
2017-03-28 17:23:01 -04:00
|
|
|
for the operators you can use.
|
|
|
|
|
|
|
|
|
|
|
|
|
2019-09-30 13:18:50 -04:00
|
|
|
==== Using an array compare condition
|
2017-03-28 17:23:01 -04:00
|
|
|
|
|
|
|
To use the `array_compare` condition, you specify the array in the execution
|
2019-09-30 13:18:50 -04:00
|
|
|
context that you want to evaluate, a
|
|
|
|
<<condition-compare-operators,comparison operator>>, and the value you want to
|
|
|
|
compare against. Optionally, you can specify the path to the field in each array
|
|
|
|
element that you want to evaluate.
|
2017-03-28 17:23:01 -04:00
|
|
|
|
|
|
|
For example, the following `array_compare` condition returns `true` if there
|
|
|
|
is at least one bucket in the aggregation that has a `doc_count` greater
|
|
|
|
than or equal to 25:
|
|
|
|
|
|
|
|
[source,js]
|
|
|
|
--------------------------------------------------
|
|
|
|
{
|
|
|
|
"condition": {
|
|
|
|
"array_compare": {
|
|
|
|
"ctx.payload.aggregations.top_tweeters.buckets" : { <1>
|
2019-02-27 12:43:21 -05:00
|
|
|
"path": "doc_count", <2>
|
2017-03-28 17:23:01 -04:00
|
|
|
"gte": { <3>
|
2019-06-07 08:17:36 -04:00
|
|
|
"value": 25 <4>
|
2017-03-28 17:23:01 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
--------------------------------------------------
|
2018-06-22 21:09:37 -04:00
|
|
|
// NOTCONSOLE
|
2017-03-28 17:23:01 -04:00
|
|
|
<1> The path to the array in the execution
|
|
|
|
context that you want to evaluate, specified in dot notation.
|
|
|
|
<2> The path to the field in each array element that you want to evaluate.
|
2019-09-30 13:18:50 -04:00
|
|
|
<3> The <<condition-compare-operators,comparison operator>> to use.
|
2017-03-28 17:23:01 -04:00
|
|
|
<4> The comparison value. Supports date math like the
|
2019-09-30 13:18:50 -04:00
|
|
|
<<compare-condition-date-math,compare condition>>.
|
2017-03-28 17:23:01 -04:00
|
|
|
|
2018-12-07 03:38:12 -05:00
|
|
|
NOTE: When using fieldnames that contain a dot this condition will not
|
|
|
|
work, use a <<condition-script,script condition>> instead.
|
|
|
|
|
2019-09-30 13:18:50 -04:00
|
|
|
==== Array-compare condition attributes
|
2017-03-28 17:23:01 -04:00
|
|
|
|
|
|
|
[options="header"]
|
|
|
|
|======
|
|
|
|
| Name | Description
|
|
|
|
|`<array path>` | The path to the array in the execution
|
|
|
|
context, specified in dot notation.
|
|
|
|
For example, `ctx.payload.aggregations.top_tweeters.buckets`.
|
|
|
|
| `<array path>.path` | The path to the field in each array element
|
|
|
|
that you want to evaluate. For example,
|
|
|
|
`doc_count`. Defaults to an empty string.
|
|
|
|
| `<array path>.<operator>.quantifier` | How many matches are required for the
|
|
|
|
comparison to evaluate to `true`: `some`
|
|
|
|
or `all`. Defaults to `some`--there must
|
|
|
|
be at least one match. If the array is
|
|
|
|
empty, the comparison evaluates to `true`
|
|
|
|
if the quantifier is set to `all` and
|
|
|
|
`false` if the quantifier is set to
|
|
|
|
`some`.
|
|
|
|
| `<array path>.<operator>.value` | The value to compare against.
|
|
|
|
|
|
|
|
|======
|