|
|
|
@ -17,6 +17,7 @@
@@ -17,6 +17,7 @@
|
|
|
|
|
package org.springframework.cloud.netflix.turbine.stream; |
|
|
|
|
|
|
|
|
|
import java.io.IOException; |
|
|
|
|
import java.util.List; |
|
|
|
|
import java.util.Map; |
|
|
|
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired; |
|
|
|
@ -56,18 +57,33 @@ public class HystrixStreamAggregator {
@@ -56,18 +57,33 @@ public class HystrixStreamAggregator {
|
|
|
|
|
payload = payload.replace("\\\"", "\""); |
|
|
|
|
} |
|
|
|
|
try { |
|
|
|
|
@SuppressWarnings("unchecked") |
|
|
|
|
Map<String, Object> map = this.objectMapper.readValue(payload, Map.class); |
|
|
|
|
Map<String, Object> data = getPayloadData(map); |
|
|
|
|
|
|
|
|
|
log.debug("Received hystrix stream payload: " + data); |
|
|
|
|
this.subject.onNext(data); |
|
|
|
|
if (payload.startsWith("[")) { |
|
|
|
|
@SuppressWarnings("unchecked") |
|
|
|
|
List<Map<String, Object>> list = this.objectMapper.readValue(payload, |
|
|
|
|
List.class); |
|
|
|
|
for (Map<String, Object> map : list) { |
|
|
|
|
sendMap(map); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
else { |
|
|
|
|
@SuppressWarnings("unchecked") |
|
|
|
|
Map<String, Object> map = this.objectMapper.readValue(payload, Map.class); |
|
|
|
|
sendMap(map); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
catch (IOException ex) { |
|
|
|
|
log.error("Error receiving hystrix stream payload: " + payload, ex); |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
private void sendMap(Map<String, Object> map) { |
|
|
|
|
Map<String, Object> data = getPayloadData(map); |
|
|
|
|
if (log.isDebugEnabled()) { |
|
|
|
|
log.debug("Received hystrix stream payload: " + data); |
|
|
|
|
} |
|
|
|
|
this.subject.onNext(data); |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
public static Map<String, Object> getPayloadData(Map<String, Object> jsonMap) { |
|
|
|
|
@SuppressWarnings("unchecked") |
|
|
|
|
Map<String, Object> origin = (Map<String, Object>) jsonMap.get("origin"); |
|
|
|
|