mirror of https://github.com/apache/nifi.git
NIFI-10303 route GetElasticsearch to failure if _id is blank after attribute evaluation
This closes #6573 Signed-off-by: Mike Thomsen <mthomsen@apache.org>
This commit is contained in:
parent
db49a861b3
commit
b6026f5709
|
@ -35,8 +35,10 @@ import org.apache.nifi.processor.AbstractProcessor;
|
||||||
import org.apache.nifi.processor.ProcessContext;
|
import org.apache.nifi.processor.ProcessContext;
|
||||||
import org.apache.nifi.processor.ProcessSession;
|
import org.apache.nifi.processor.ProcessSession;
|
||||||
import org.apache.nifi.processor.Relationship;
|
import org.apache.nifi.processor.Relationship;
|
||||||
|
import org.apache.nifi.processor.exception.ProcessException;
|
||||||
import org.apache.nifi.processor.util.StandardValidators;
|
import org.apache.nifi.processor.util.StandardValidators;
|
||||||
import org.apache.nifi.util.StopWatch;
|
import org.apache.nifi.util.StopWatch;
|
||||||
|
import org.apache.nifi.util.StringUtils;
|
||||||
|
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
@ -161,6 +163,10 @@ public class GetElasticsearch extends AbstractProcessor implements Elasticsearch
|
||||||
final String attributeName = context.getProperty(ATTRIBUTE_NAME).evaluateAttributeExpressions(input).getValue();
|
final String attributeName = context.getProperty(ATTRIBUTE_NAME).evaluateAttributeExpressions(input).getValue();
|
||||||
|
|
||||||
try {
|
try {
|
||||||
|
if (StringUtils.isBlank(id)) {
|
||||||
|
throw new ProcessException(ID.getDisplayName() + " is blank (after evaluating attribute expressions), cannot GET document");
|
||||||
|
}
|
||||||
|
|
||||||
final StopWatch stopWatch = new StopWatch(true);
|
final StopWatch stopWatch = new StopWatch(true);
|
||||||
final Map<String, Object> doc = clientService.get(index, type, id, getUrlQueryParameters(context, input));
|
final Map<String, Object> doc = clientService.get(index, type, id, getUrlQueryParameters(context, input));
|
||||||
|
|
||||||
|
@ -182,6 +188,19 @@ public class GetElasticsearch extends AbstractProcessor implements Elasticsearch
|
||||||
session.getProvenanceReporter().receive(documentFlowFile, clientService.getTransitUrl(index, type), stopWatch.getElapsed(TimeUnit.MILLISECONDS));
|
session.getProvenanceReporter().receive(documentFlowFile, clientService.getTransitUrl(index, type), stopWatch.getElapsed(TimeUnit.MILLISECONDS));
|
||||||
session.transfer(documentFlowFile, REL_DOC);
|
session.transfer(documentFlowFile, REL_DOC);
|
||||||
} catch (final ElasticsearchException ese) {
|
} catch (final ElasticsearchException ese) {
|
||||||
|
handleElasticsearchException(ese, input, session, index, type, id);
|
||||||
|
} catch (final Exception ex) {
|
||||||
|
getLogger().error("Could not fetch document.", ex);
|
||||||
|
if (input != null) {
|
||||||
|
input = session.putAttribute(input, "elasticsearch.get.error", ex.getMessage());
|
||||||
|
session.transfer(input, REL_FAILURE);
|
||||||
|
}
|
||||||
|
context.yield();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void handleElasticsearchException(final ElasticsearchException ese, FlowFile input, final ProcessSession session,
|
||||||
|
final String index, final String type, final String id) {
|
||||||
if (ese.isNotFound()) {
|
if (ese.isNotFound()) {
|
||||||
if (input != null) {
|
if (input != null) {
|
||||||
session.transfer(input, REL_NOT_FOUND);
|
session.transfer(input, REL_NOT_FOUND);
|
||||||
|
@ -198,13 +217,5 @@ public class GetElasticsearch extends AbstractProcessor implements Elasticsearch
|
||||||
session.transfer(input, ese.isElastic() ? REL_RETRY : REL_FAILURE);
|
session.transfer(input, ese.isElastic() ? REL_RETRY : REL_FAILURE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (final Exception ex) {
|
|
||||||
getLogger().error("Could not fetch document.", ex);
|
|
||||||
if (input != null) {
|
|
||||||
input = session.putAttribute(input, "elasticsearch.get.error", ex.getMessage());
|
|
||||||
session.transfer(input, REL_FAILURE);
|
|
||||||
}
|
|
||||||
context.yield();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -191,6 +191,18 @@ class GetElasticsearchTest {
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
void testRequestParameters() {
|
void testRequestParameters() {
|
||||||
|
final TestRunner runner = createRunner()
|
||||||
|
runner.setProperty(GetElasticsearch.ID, "\${noAttribute}")
|
||||||
|
|
||||||
|
runProcessor(runner)
|
||||||
|
testCounts(runner, 0, 1, 0, 0)
|
||||||
|
final FlowFile failed = runner.getFlowFilesForRelationship(GetElasticsearch.REL_FAILURE).get(0)
|
||||||
|
failed.assertAttributeEquals("elasticsearch.get.error", GetElasticsearch.ID.getDisplayName() + " is blank (after evaluating attribute expressions), cannot GET document")
|
||||||
|
reset(runner)
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void testEmptyId() {
|
||||||
final TestRunner runner = createRunner()
|
final TestRunner runner = createRunner()
|
||||||
runner.setProperty("refresh", "true")
|
runner.setProperty("refresh", "true")
|
||||||
runner.setProperty("_source", '${source}')
|
runner.setProperty("_source", '${source}')
|
||||||
|
|
Loading…
Reference in New Issue