com.aliyun.datahub.model.serialize.CommitOffsetRequestJsonSer Maven / Gradle / Ivy
package com.aliyun.datahub.model.serialize;
import com.aliyun.datahub.common.transport.DefaultRequest;
import com.aliyun.datahub.common.transport.HttpMethod;
import com.aliyun.datahub.common.util.JacksonParser;
import com.aliyun.datahub.exception.DatahubClientException;
import com.aliyun.datahub.model.CommitOffsetRequest;
import com.aliyun.datahub.model.OffsetContext;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ObjectNode;
import java.io.IOException;
import java.util.Map;
public class CommitOffsetRequestJsonSer implements Serializer {
@Override
public DefaultRequest serialize(CommitOffsetRequest request) throws DatahubClientException {
DefaultRequest req = new DefaultRequest();
req.setResource("/projects/" + request.getProject() + "/topics/" + request.getTopic() + "/subscriptions/" + request.getSubId() + "/offsets");
req.setHttpMethod(HttpMethod.PUT);
ObjectMapper mapper = JacksonParser.getObjectMapper();
ObjectNode node = mapper.createObjectNode();
node.put("Action", "commit");
ObjectNode offsets = node.putObject("Offsets");
for (Map.Entry offset: request.getOffsetCtxMap().entrySet()) {
ObjectNode offsetNode = offsets.putObject(offset.getKey());
offsetNode.put("Sequence", offset.getValue().getOffset().getSequence());
offsetNode.put("Timestamp", offset.getValue().getOffset().getTimestamp());
offsetNode.put("Version", offset.getValue().getVersion());
offsetNode.put("SessionId", Long.parseLong(offset.getValue().getSessionId()));
}
try {
req.setBody(mapper.writeValueAsString(node));
} catch (IOException e) {
throw new DatahubClientException("serialize error", e);
}
return req;
}
private CommitOffsetRequestJsonSer() {}
private static CommitOffsetRequestJsonSer instance;
public static CommitOffsetRequestJsonSer getInstance() {
if (instance == null) {
instance = new CommitOffsetRequestJsonSer();
}
return instance;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy