Tinderbox can process JSON stored in any attribute, including $Text. JSON stream operators are expecting the whole contents of the stream to be a valid JSON object.
If there is no current JSON object, attempts to parse the string as JSON and fails if unsuccessful. If there is a current JSON object, that object will be reused. If the top-level element is an object, JSON.json[key] returns a dictionary for that object.
If there is no current JSON object, attempts to parse the string as JSON and fails if unsuccessful. If there is a current JSON object, that object will be reused. If the top-level element is an array, JSON.json[N] returns the Nth object.
If the top-level element is an array, rebinds the JSON object in turn to each array element. After calling the action block for each element, the JSON object is restored.
Attempts to parse the Stream's string and re-scope it it as only the (first) JSON code detected within the text. It fails if unsuccessful.
JSON property chaining
JSON doesn't have a formal pathing method like XPath in XML, but JSON properties can be chained to allow navigation to nested objects. For example, consider:
{
"person": { "firstName": "Thomas", lastName: "Roe"},
"coordinates" : [-90,41]
}
Thomas’s latitude can be addressed via
$Text.json["coordinates"][0]
And his family name via
$Text.json["person.lastName"]