From 39ca65c7e352b4c8c7267f483eadfd847ef3befc Mon Sep 17 00:00:00 2001 From: Aaron Bretz Date: Tue, 14 Nov 2023 20:18:23 -0600 Subject: [PATCH] add support for JsonPointer notation --- .../impl/payload/JsonFieldToMapPayloadExtractor.java | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/modules/flowable-event-registry/src/main/java/org/flowable/eventregistry/impl/payload/JsonFieldToMapPayloadExtractor.java b/modules/flowable-event-registry/src/main/java/org/flowable/eventregistry/impl/payload/JsonFieldToMapPayloadExtractor.java index 105172782ee..cab73a5bac5 100644 --- a/modules/flowable-event-registry/src/main/java/org/flowable/eventregistry/impl/payload/JsonFieldToMapPayloadExtractor.java +++ b/modules/flowable-event-registry/src/main/java/org/flowable/eventregistry/impl/payload/JsonFieldToMapPayloadExtractor.java @@ -15,6 +15,7 @@ import java.util.Collection; import java.util.stream.Collectors; +import com.fasterxml.jackson.core.JsonPointer; import org.flowable.eventregistry.api.InboundEventPayloadExtractor; import org.flowable.eventregistry.api.model.EventPayloadTypes; import org.flowable.eventregistry.api.runtime.EventPayloadInstance; @@ -36,7 +37,10 @@ public class JsonFieldToMapPayloadExtractor implements InboundEventPayloadExtrac @Override public Collection extractPayload(EventModel eventModel, JsonNode payload) { return eventModel.getPayload().stream() - .filter(payloadDefinition -> payloadDefinition.isFullPayload() || payload.has(payloadDefinition.getName())) + .filter(payloadDefinition -> payloadDefinition.isFullPayload() + || payload.has(payloadDefinition.getName()) + || (payloadDefinition.getName().startsWith("/") + && !payload.at(JsonPointer.valueOf(payloadDefinition.getName())).isMissingNode())) .map(payloadDefinition -> new EventPayloadInstanceImpl(payloadDefinition, getPayloadValue(payload, payloadDefinition.getName(), payloadDefinition.getType(), payloadDefinition.isFullPayload()))) .collect(Collectors.toList()); @@ -46,8 +50,9 @@ protected Object getPayloadValue(JsonNode event, String definitionName, String d if (isFullPayload) { return event; } - - JsonNode parameterNode = event.get(definitionName); + + JsonNode parameterNode = definitionName.startsWith("/") + ? event.at(JsonPointer.valueOf(definitionName)) : event.get(definitionName); Object value = null; if (EventPayloadTypes.STRING.equals(definitionType)) {