GH-422, GH-606 Fis structure mode attribute generation
This commit is contained in:
@@ -18,6 +18,7 @@ package org.springframework.cloud.function.cloudevent;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
import java.util.UUID;
|
||||
|
||||
import org.springframework.util.StringUtils;
|
||||
|
||||
@@ -101,6 +102,10 @@ public class CloudEventAttributes extends HashMap<String, Object> {
|
||||
else if (this.containsKey(CloudEventMessageUtils.HTTP_ATTR_PREFIX + CloudEventMessageUtils.ID)) {
|
||||
return (A) this.get(CloudEventMessageUtils.HTTP_ATTR_PREFIX + CloudEventMessageUtils.ID);
|
||||
}
|
||||
Object id = this.get(CloudEventMessageUtils.ID);
|
||||
if (!(id instanceof UUID)) {
|
||||
return (A) id;
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
|
||||
@@ -237,9 +237,10 @@ public final class CloudEventMessageUtils {
|
||||
.parseMimeType(contentType.getType() + "/" + suffix);
|
||||
Message<?> cloudEventMessage = MessageBuilder.fromMessage(inputMessage)
|
||||
.setHeader(MessageHeaders.CONTENT_TYPE, cloudEventDeserializationContentType)
|
||||
.setHeader(CloudEventMessageUtils.CANONICAL_DATACONTENTTYPE, dataContentType).build();
|
||||
.setHeader(CloudEventMessageUtils.CANONICAL_DATACONTENTTYPE, dataContentType)
|
||||
.build();
|
||||
Map<String, Object> structuredCloudEvent = (Map<String, Object>) messageConverter.fromMessage(cloudEventMessage, Map.class);
|
||||
Message<?> binaryCeMessage = buildCeMessageFromStructured(structuredCloudEvent, determinePrefixToUse(inputMessage));
|
||||
Message<?> binaryCeMessage = buildCeMessageFromStructured(structuredCloudEvent, inputMessage.getHeaders());
|
||||
return binaryCeMessage;
|
||||
}
|
||||
}
|
||||
@@ -251,7 +252,8 @@ public final class CloudEventMessageUtils {
|
||||
return inputMessage;
|
||||
}
|
||||
|
||||
private static Message<?> buildCeMessageFromStructured(Map<String, Object> structuredCloudEvent, String prefixToUse) {
|
||||
private static Message<?> buildCeMessageFromStructured(Map<String, Object> structuredCloudEvent, MessageHeaders originalHeaders) {
|
||||
String prefixToUse = determinePrefixToUse(originalHeaders);
|
||||
Object data = null;
|
||||
if (structuredCloudEvent.containsKey(CloudEventMessageUtils.HTTP_ATTR_PREFIX + CloudEventMessageUtils.DATA)) {
|
||||
data = structuredCloudEvent.get(CloudEventMessageUtils.HTTP_ATTR_PREFIX + CloudEventMessageUtils.DATA);
|
||||
@@ -272,11 +274,12 @@ public final class CloudEventMessageUtils {
|
||||
builder.setHeader(prefixToUse + CloudEventMessageUtils.SOURCE, attributes.getSource());
|
||||
builder.setHeader(prefixToUse + CloudEventMessageUtils.TYPE, attributes.getType());
|
||||
builder.setHeader(prefixToUse + CloudEventMessageUtils.SPECVERSION, attributes.getSpecversion());
|
||||
builder.copyHeaders(originalHeaders);
|
||||
return builder.build();
|
||||
}
|
||||
|
||||
public static String determinePrefixToUse(Message<?> inputMessage) {
|
||||
Set<String> keys = inputMessage.getHeaders().keySet();
|
||||
public static String determinePrefixToUse(MessageHeaders messageHeaders) {
|
||||
Set<String> keys = messageHeaders.keySet();
|
||||
if (keys.contains("user-agent")) {
|
||||
return CloudEventMessageUtils.HTTP_ATTR_PREFIX;
|
||||
}
|
||||
@@ -296,9 +299,9 @@ public final class CloudEventMessageUtils {
|
||||
return attributes;
|
||||
}
|
||||
|
||||
public static CloudEventAttributes generateAttributes(Message<?> inputMessage, Object result, String applicationName) {
|
||||
CloudEventAttributes attributes = new CloudEventAttributes(inputMessage.getHeaders(), CloudEventMessageUtils.determinePrefixToUse(inputMessage));
|
||||
return generateDefaultAttributeValues(attributes, result.getClass().getName(), applicationName);
|
||||
public static CloudEventAttributes generateAttributes(Message<?> inputMessage, String typeName, String sourceName) {
|
||||
CloudEventAttributes attributes = new CloudEventAttributes(inputMessage.getHeaders(), CloudEventMessageUtils.determinePrefixToUse(inputMessage.getHeaders()));
|
||||
return generateDefaultAttributeValues(attributes, typeName, sourceName);
|
||||
}
|
||||
|
||||
private static CloudEventAttributes generateDefaultAttributeValues(CloudEventAttributes attributes, String source, String type) {
|
||||
|
||||
@@ -163,13 +163,12 @@ public class BeanFactoryAwareFunctionRegistry extends SimpleFunctionRegistry imp
|
||||
|
||||
if (function != null) {
|
||||
BiFunction<Message<?>, Object, Message<?>> invocationResultHeaderEnricher = new BiFunction<Message<?>, Object, Message<?>>() {
|
||||
|
||||
@Override
|
||||
public Message<?> apply(Message<?> inputMessage, Object invocationResult) {
|
||||
// TODO: Factor it out! Cloud Events specific code
|
||||
CloudEventAttributes generatedCeHeaders = CloudEventMessageUtils
|
||||
.generateAttributes(inputMessage, invocationResult, getApplicationName());
|
||||
CloudEventAttributes attributes = new CloudEventAttributes(generatedCeHeaders, CloudEventMessageUtils.determinePrefixToUse(inputMessage));
|
||||
.generateAttributes(inputMessage, invocationResult.getClass().getName(), getApplicationName());
|
||||
CloudEventAttributes attributes = new CloudEventAttributes(generatedCeHeaders, CloudEventMessageUtils.determinePrefixToUse(inputMessage.getHeaders()));
|
||||
if (cloudEventAtttributesProvider != null) {
|
||||
cloudEventAtttributesProvider.generateDefaultCloudEventHeaders(attributes);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user