|
16 | 16 |
|
17 | 17 | package org.springframework.cloud.function.context.config;
|
18 | 18 |
|
| 19 | +import java.lang.reflect.Type; |
| 20 | +import java.util.ArrayList; |
19 | 21 | import java.util.Collection;
|
20 | 22 | import java.util.List;
|
21 | 23 |
|
22 | 24 | import org.apache.commons.logging.Log;
|
23 | 25 | import org.apache.commons.logging.LogFactory;
|
24 | 26 |
|
| 27 | +import org.springframework.cloud.function.context.catalog.FunctionTypeUtils; |
25 | 28 | import org.springframework.lang.Nullable;
|
26 | 29 | import org.springframework.messaging.Message;
|
27 | 30 | import org.springframework.messaging.MessageHeaders;
|
28 | 31 | import org.springframework.messaging.converter.AbstractMessageConverter;
|
29 | 32 | import org.springframework.messaging.converter.CompositeMessageConverter;
|
30 | 33 | import org.springframework.messaging.converter.MessageConverter;
|
31 | 34 | import org.springframework.messaging.converter.SmartMessageConverter;
|
| 35 | +import org.springframework.messaging.support.MessageBuilder; |
32 | 36 | import org.springframework.messaging.support.MessageHeaderAccessor;
|
| 37 | +import org.springframework.util.CollectionUtils; |
33 | 38 | import org.springframework.util.MimeType;
|
34 | 39 | import org.springframework.util.StringUtils;
|
35 | 40 |
|
@@ -75,11 +80,38 @@ public Object fromMessage(Message<?> message, Class<?> targetClass, @Nullable Ob
|
75 | 80 | if (!(message.getPayload() instanceof byte[]) && targetClass.isInstance(message.getPayload()) && !(message.getPayload() instanceof Collection<?>)) {
|
76 | 81 | return message.getPayload();
|
77 | 82 | }
|
78 |
| - Object result = (converter instanceof SmartMessageConverter ? |
79 |
| - ((SmartMessageConverter) converter).fromMessage(message, targetClass, conversionHint) : |
80 |
| - converter.fromMessage(message, targetClass)); |
81 |
| - if (result != null) { |
82 |
| - return result; |
| 83 | + |
| 84 | + if (message.getPayload() instanceof Iterable && conversionHint != null) { |
| 85 | + Iterable<Object> iterablePayload = (Iterable) message.getPayload(); |
| 86 | + Type t = FunctionTypeUtils.getImmediateGenericType((Type) conversionHint, 0); |
| 87 | + Class rawType = FunctionTypeUtils.getRawType(t); |
| 88 | + List<Object> resultList = new ArrayList<>(); |
| 89 | + for (Object item : iterablePayload) { |
| 90 | + /* |
| 91 | + * Somewhere here we can do KafkaNull check or see below |
| 92 | + */ |
| 93 | + Message m = MessageBuilder.withPayload(item).copyHeaders(message.getHeaders()).build(); |
| 94 | + Object result = (converter instanceof SmartMessageConverter & rawType != t ? |
| 95 | + ((SmartMessageConverter) converter).fromMessage(m, rawType, t) : |
| 96 | + converter.fromMessage(m, rawType)); |
| 97 | + if (result != null) { |
| 98 | + /* |
| 99 | + * Or most likely here we can do the KafkaNull check and not add it to the list |
| 100 | + */ |
| 101 | + resultList.add(result); |
| 102 | + } |
| 103 | + } |
| 104 | + if (!CollectionUtils.isEmpty(resultList)) { |
| 105 | + return resultList; |
| 106 | + } |
| 107 | + } |
| 108 | + else { |
| 109 | + Object result = (converter instanceof SmartMessageConverter ? |
| 110 | + ((SmartMessageConverter) converter).fromMessage(message, targetClass, conversionHint) : |
| 111 | + converter.fromMessage(message, targetClass)); |
| 112 | + if (result != null) { |
| 113 | + return result; |
| 114 | + } |
83 | 115 | }
|
84 | 116 | }
|
85 | 117 | return null;
|
|
0 commit comments