Applies a JSLT transformation to the FlowFile JSON payload. A new FlowFile is created with transformed content and is routed to the 'success' relationship. If the JSLT transform fails, the original FlowFile is routed to the 'failure' relationship.
json, jslt, transform
In the list below, the names of required properties appear in bold. Any other properties (not in bold) are considered optional. The table also indicates any default values, and whether a property supports the NiFi Expression Language.
| Display Name | API Name | Default Value | Allowable Values | Description |
|---|---|---|---|---|
| JSLT Transformation | jslt-transform-transformation | JSLT Transformation for transform of JSON data. Any NiFi Expression Language present will be evaluated first to get the final transform to be applied. The JSLT Tutorial provides an overview of supported expressions: https://github.com/schibsted/jslt/blob/master/tutorial.md This property requires exactly one resource to be provided. That resource may be any of the following types: file, text. Supports Expression Language: true (will be evaluated using flow file attributes and variable registry) | ||
| Transformation Strategy | jslt-transform-transformation-strategy | Entire FlowFile |
| Whether to apply the JSLT transformation to the entire FlowFile contents or each JSON object in the root-level array |
| Pretty Print | jslt-transform-pretty_print | false |
| Apply pretty-print formatting to the output of the JSLT transform |
| Transform Cache Size | jslt-transform-cache-size | 1 | Compiling a JSLT Transform can be fairly expensive. Ideally, this will be done only once. However, if the Expression Language is used in the transform, we may need a new Transform for each FlowFile. This value controls how many of those Transforms we cache in memory in order to avoid having to compile the Transform each time. | |
| Transform Result Filter | jslt-transform-result-filter | . != null and . != {} and . != [] | A filter for output JSON results using a JSLT expression. This property supports changing the default filter, which removes JSON objects with null values, empty objects and empty arrays from the output JSON. This JSLT must return true for each JSON object to be included and false for each object to be removed. Using a filter value of "true" to disables filtering. |
| Name | Description |
|---|---|
| success | The FlowFile with transformed content will be routed to this relationship |
| failure | If a FlowFile fails processing for any reason (for example, the FlowFile is not valid JSON), it will be routed to this relationship |
| Name | Description |
|---|---|
| mime.type | Always set to application/json |
| Resource | Description |
|---|---|
| MEMORY | An instance of this component can cause high usage of this system resource. Multiple instances or high concurrency settings may result a degradation of performance. |