com.aliyun.datahub.model.serialize.GetOffsetResultJsonDeser Maven / Gradle / Ivy
package com.aliyun.datahub.model.serialize;
import com.aliyun.datahub.common.transport.Response;
import com.aliyun.datahub.common.util.JacksonParser;
import com.aliyun.datahub.exception.DatahubServiceException;
import com.aliyun.datahub.model.GetOffsetResult;
import com.aliyun.datahub.model.OffsetContext;
import com.aliyun.datahub.model.GetOffsetRequest;
import org.codehaus.jackson.JsonNode;
import org.codehaus.jackson.map.ObjectMapper;
import java.io.IOException;
import java.util.*;
public class GetOffsetResultJsonDeser implements Deserializer {
@Override
public GetOffsetResult deserialize(GetOffsetRequest request, Response response) throws DatahubServiceException {
if (!response.isOK()) {
throw JsonErrorParser.getInstance().parse(response);
}
GetOffsetResult rs = new GetOffsetResult();
ObjectMapper mapper = JacksonParser.getObjectMapper();
JsonNode tree = null;
try {
tree = mapper.readTree(response.getBody());
} catch (IOException e) {
throw new DatahubServiceException(
"JsonParseError", "Parse body failed:" + response.getBody(), response);
}
JsonNode offsetsNode = tree.get("Offsets");
if (!offsetsNode.isObject()) {
throw new DatahubServiceException("JsonParseError", "invalid offsets node value", response);
}
Map offsets = new HashMap();
Map versions = new HashMap();
Iterator> iterator = offsetsNode.getFields();
while (iterator.hasNext()) {
Map.Entry offsetNode = iterator.next();
offsets.put(offsetNode.getKey(), new OffsetContext.Offset(offsetNode.getValue().get("Sequence").asLong(),
offsetNode.getValue().get("Timestamp").asLong()));
versions.put(offsetNode.getKey(), offsetNode.getValue().get("Version").asLong());
}
rs.setOffsets(offsets);
rs.setVersions(versions);
return rs;
}
private GetOffsetResultJsonDeser() {}
private static GetOffsetResultJsonDeser instance;
public static GetOffsetResultJsonDeser getInstance() {
if (instance == null) {
instance = new GetOffsetResultJsonDeser();
}
return instance;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy