From 5b7af511fc1187676d5e0eefe7c3899ef102246d Mon Sep 17 00:00:00 2001 From: Mark Payne Date: Thu, 23 Sep 2021 09:12:27 -0400 Subject: [PATCH] NIFI-8273: Fix typos in docs/clarify some statements. Addressed handling of arrays as partitions This closes #4948. --- .../processors/script/ScriptedPartitionRecord.java | 14 ++++++++------ .../additionalDetails.html | 13 +++++-------- .../additionalDetails.html | 5 +++-- .../script/TestScriptedPartitionRecord.java | 2 +- 4 files changed, 17 insertions(+), 17 deletions(-) diff --git a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/java/org/apache/nifi/processors/script/ScriptedPartitionRecord.java b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/java/org/apache/nifi/processors/script/ScriptedPartitionRecord.java index d0cb89f687..2890436cfc 100644 --- a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/java/org/apache/nifi/processors/script/ScriptedPartitionRecord.java +++ b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/java/org/apache/nifi/processors/script/ScriptedPartitionRecord.java @@ -50,6 +50,7 @@ import javax.script.ScriptException; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; +import java.util.Arrays; import java.util.HashMap; import java.util.HashSet; import java.util.List; @@ -67,7 +68,8 @@ import java.util.Set; explanation = "Provides operator the ability to execute arbitrary code assuming all permissions that NiFi has.") }) @WritesAttributes({ - @WritesAttribute(attribute = "partition", description = "The partition of the outgoing flow file."), + @WritesAttribute(attribute = "partition", description = "The partition of the outgoing flow file. If the script indicates that the partition has a null value, the attribute will be set to " + + "the literal string \"\" (without quotes). Otherwise, the attribute is set to the String representation of whatever value is returned by the script."), @WritesAttribute(attribute = "mime.type", description = "Sets the mime.type attribute to the MIME Type specified by the Record Writer"), @WritesAttribute(attribute = "record.count", description = "The number of records within the flow file."), @WritesAttribute(attribute = "record.error.message", description = "This attribute provides on failure the error message encountered by the Reader or Writer."), @@ -167,8 +169,8 @@ public class ScriptedPartitionRecord extends ScriptedRecordProcessor { final RecordSet recordSet = reader.createRecordSet(); final PushBackRecordSet pushBackSet = new PushBackRecordSet(recordSet); - final Map outgoingFlowFiles = new HashMap<>(); - final Map recordSetWriters = new HashMap<>(); + final Map outgoingFlowFiles = new HashMap<>(); + final Map recordSetWriters = new HashMap<>(); // Reading in records and evaluate script while (pushBackSet.isAnotherRecord()) { @@ -177,7 +179,7 @@ public class ScriptedPartitionRecord extends ScriptedRecordProcessor { getLogger().debug("Evaluated scripted against {} (index {}), producing result of {}", record, counts.getRecordCount(), evaluatedValue); counts.incrementRecordCount(); - final String partition = (evaluatedValue == null) ? null : evaluatedValue.toString(); + final Object partition = (evaluatedValue instanceof Object[]) ? Arrays.asList((Object[]) evaluatedValue) : evaluatedValue; RecordSetWriter writer = recordSetWriters.get(partition); if (writer == null) { @@ -196,13 +198,13 @@ public class ScriptedPartitionRecord extends ScriptedRecordProcessor { // Sending outgoing flow files int fragmentIndex = 0; - for (final String partition : outgoingFlowFiles.keySet()) { + for (final Object partition : outgoingFlowFiles.keySet()) { final RecordSetWriter writer = recordSetWriters.get(partition); final FlowFile outgoingFlowFile = outgoingFlowFiles.get(partition); final Map attributes = new HashMap<>(incomingFlowFile.getAttributes()); attributes.put("mime.type", writer.getMimeType()); - attributes.put("partition", partition); + attributes.put("partition", partition == null ? "" : partition.toString()); attributes.put("fragment.index", String.valueOf(fragmentIndex)); attributes.put("fragment.count", String.valueOf(outgoingFlowFiles.size())); diff --git a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedPartitonRecord/additionalDetails.html b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedPartitonRecord/additionalDetails.html index 585088aa1e..e68a786f38 100644 --- a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedPartitonRecord/additionalDetails.html +++ b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedPartitonRecord/additionalDetails.html @@ -33,14 +33,14 @@ td {text-align: left}

Description

- The ScriptedPartitionRecord provides the ability to use a scripting language, such as Groovy or Jython, to quickly and easily partition a Record based on the contents of it. + The ScriptedPartitionRecord provides the ability to use a scripting language, such as Groovy or Jython, to quickly and easily partition a Record based on its contents. There are multiple ways to reach the same behaviour such as using PartitionRecord but working with user provided scripts opens a wide range of possibilities on the decision logic of partitioning the individual records.

The provided script is evaluated once for each Record that is encountered in the incoming FlowFile. Each time that the script is invoked, it is expected to return an object or a null value. - The string representation of the return value is used as "partition". The null value is handled separately without conversion into string. + The string representation of the return value is used as the record's "partition". The null value is handled separately without conversion into string. All Records with the same partition then will be batched to one FlowFile and routed to the success Relationship.

@@ -89,17 +89,14 @@ td {text-align: left}

Return Value

- The script is invoked separately for each Record. It is accepted to return with any Object values might be represented as string. This string value will be used as the partition of the given Record. - Alternately it is possible to return with null value. - - Each time the script is invoked, it is expected to return a boolean value. Return values other than boolean, including null value will be handled as - unexpected script behaviour and handled accordingly: the processing will be interrupted and the incoming FlowFile will be transferred to the failure relationship without further execution. + The script is invoked separately for each Record. It is acceptable to return any Object might be represented as string. This string value will be used as the partition of the given + Record. Additionally, the script may return null.

Example

- The following script + The following script will partition the input on the value of the "stellarType" field.

diff --git a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedValidateRecord/additionalDetails.html b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedValidateRecord/additionalDetails.html index 965b068fba..37941566de 100644 --- a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedValidateRecord/additionalDetails.html +++ b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/main/resources/docs/org.apache.nifi.processors.script.ScriptedValidateRecord/additionalDetails.html @@ -34,8 +34,9 @@ td {text-align: left}

The ScriptedValidateRecord Processor provides the ability to use a scripting language, such as Groovy or Jyton in order to validate Records in an incoming FlowFile. - NiFi provides several different Processors that can be used to work with Records in different ways. Each of these processors has its pros and cons. - The ScriptedValidateRecord is intended to work together with these processors and be used as a preliminary step in order to prevent more complex processing steps from working with incorrect Records. + The provided script will be evaluated against each Record in an incoming FlowFile. Each of those records will then be routed to either the "valid" or "invalid" FlowFile. + As a result, each incoming FlowFile may be broken up into two individual FlowFiles (if some records are valid and some are invalid, according to the script), or the incoming FlowFile + may have all of its Records kept together in a single FlowFile, routed to either "valid" or "invalid" (if all records are valid or if all records are invalid, according to the script).

diff --git a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/test/java/org/apache/nifi/processors/script/TestScriptedPartitionRecord.java b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/test/java/org/apache/nifi/processors/script/TestScriptedPartitionRecord.java index 1c169cd9b5..c8d4178589 100644 --- a/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/test/java/org/apache/nifi/processors/script/TestScriptedPartitionRecord.java +++ b/nifi-nar-bundles/nifi-scripting-bundle/nifi-scripting-processors/src/test/java/org/apache/nifi/processors/script/TestScriptedPartitionRecord.java @@ -37,7 +37,7 @@ public class TestScriptedPartitionRecord extends TestScriptedRouterProcessor { private static final String PARTITION_1 = "partition1"; private static final String PARTITION_2 = "partition2"; private static final Integer PARTITION_3 = 3; - private static final String PARTITION_4 = null; + private static final String PARTITION_4 = ""; @Test public void testIncomingFlowFileContainsNoRecords() {