Patterns are added to Quamina instances using the
AddPattern
API. This document specifies the syntax and
semantics of Patterns.
The discussion of JSON constructs in this document uses the terminology specified in RFC 8259.
Patterns exist to match Fields in incoming Events. At launch, Quamina supports only JSON syntax for Events. An Event MUST be equivalent to a JSON Object in the sense that it consists of an unordered set of members, each identified by a name which is string composed of Unicode characters.
As in JSON, the allowed member values may be strings,
numbers, the literals true
, false
, and null
, arrays,
and objects. We refer to values which are neither arrays
nor objects as Leaf values.
A Field is the combination of a Leaf value and a Path, a list of strings which are the Field names that must be traversed to reach it from the Event root.
For example, in the Event
{"alpha": {"beta": 1}}
There is only one Field whose Leaf value is 1
and whose Path is "alpha","beta"
.
Paths omit arrays. So in the Event
{"alpha": [ {"beta": [1, 2]}, {"beta": [3, 4]} ] }
The Path for the Leaf value 1
is still "alpha","beta"
A Pattern MUST be a JSON object all of whose Leaf values MUST be in arrays.
Note that a Field in an Event may have multiple Leaf Values if the Field's value is an array.
To match a Field in an Event, the Pattern MUST contain an exactly-matching Path whose value MUST be an array which contains either an Event Field Leaf value or an Extended Pattern which matches an Event Field Leaf value.
Thus, the following Pattern would match both JSON events above:
{"alpha": {"beta": [1]}}
Quamina can match numeric values with precision and range exactly the same as that provided by
Go's float64
data type, which is said to conform to IEEE 754 binary64
.
An Extended Pattern MUST be a JSON object containing a single field whose name is called the Pattern Type.
The Pattern Type of a Prefix Pattern is prefix
and its value
MUST be a string.
The following event:
{"a": "alpha"}
would be matched by this Prefix Pattern:
{"a": [ { "prefix": "al" } ] }
The Pattern Type of an Exists Pattern is exists
and its
value MUST be true
or false
. Here
are two Exists Patterns that would match the Events above:
{"alpha": {"beta": [ {"exists": true} ]}}
{"alpha": {"gamma": [ {"exists": false} ]}}
If a Field in a Pattern contains an Exists Pattern, it MUST NOT contain any other values.
Exists Patterns currently only work on leaf nodes. That is to say, given this event:
{ "a": { "b": 1 } }
The following pattern will not match:
{ "a": [ {"exists": true} ] }
We may be able to change this in future.
The case of empty arrays is interesting, both in Patterns and Events. Consider this event:
{ "a": [] }
Then "exists": true
does not match but "exists": false
does.
I.e., only the first of the two sample patterns below matches.
{ "a": [ { "exists": false } ] }
{ "a": [ { "exists": true } ] }
This makes sense in the context of the leaf-node semantics; there
really is no value for the "a"
field.
In Patterns, the following never matches any Event:
{ "a": [] }
Once again, there is nothing in the array of candidate values in the Pattern that can match any value of an "a"
field in an Event.
The Pattern Type of an Anything-But Pattern is
anything-but
and its value MUST be an array
of strings. It will match a string value which
is not equal to any of the strings in the array.
If a Field in a Pattern contains an Anything-But Pattern, it MUST NOT contain any other values.
The Pattern Type of a Wildcard Pattern is wildcard
and its value MUST be a string which MAY contain
*
(“star”) characters. The star character
functions exactly as the same character does in
command-line processors which descend from Unix’s
shell; i.e., matches the regular expression .*
Adjacent *
characters are not allowed.
Consider the following Event:
{"img": "https://example.com/9943.jpg"}
The following Wildcard Patterns would match it:
{"img": [ {"wildcard": "*.jpg"} ] }
{"img": [ {"wildcard": "https://example.com/*"} ] }
{"img": [ {"wildcard": "https://example.com/*.jpg"} ] }
{"img": [ {"wildcard": "https://example.*/*.jpg"} ] }
If it is desired to match the actual character "*", it may be “escaped” with backslash, "". For example, consider the following Event:
{"example-regex": "a**\\.b"}
The following Wildcard pattern would match it.
{"example-regex": [ {"wildcard": "a\\*\\*\\\\.b"}]}
Note that the "" backslashes must be doubled to deal with the fact that they are escape characters for JSON as well as for Quamina.
After a "", the appearance of any character other than "*" or "" is an error.
The Pattern Type of a Regexp Pattern is regexp
and its value
MUST be a string. For details of that string’s syntax see
Regular Expressions in Quamina.
This is an earlier version of the Wildcard pattern, differing only that -escaping the "*" and "" characters is not supported.
The Pattern Type of an Equals-Ignore-Case pattern is equals-ignore-case
and its value MUST be a string. Quamina attempts to match with
case folding in effect, as discussed in Section 3.13 of the Unicode
Standard. Quamina uses the case-folding mappings provided in the file
CaseFolding.txt in the Unicode Character Database to generate its mappings.
Note that case-folding is highly dependent on the specifics of the language
in use and in certain locales, this default mapping may not produce satisfactory
results, although results are good for ASCII and "simple" characters from
other alphabets.
Quamina’s Patterns are inspired by those offered by the AWS EventBridge service, as documented in Amazon EventBridge event patterns.
It is a goal of Quamina to eventually support all the patterns that EventBridge does.