com.aliyun.datahub.model.serialize.InitOffsetContextRequestJsonSer 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.InitOffsetContextRequest;
import com.fasterxml.jackson.core.JsonGenerationException;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ArrayNode;
import com.fasterxml.jackson.databind.node.ObjectNode;
import java.io.IOException;
public class InitOffsetContextRequestJsonSer implements Serializer {
@Override
public DefaultRequest serialize(InitOffsetContextRequest request) throws DatahubClientException {
DefaultRequest req = new DefaultRequest();
req.setHttpMethod(HttpMethod.POST);
req.setResource("/projects/" + request.getProjectName() + "/topics/" + request.getTopicName()
+ "/subscriptions/" + request.getSubId() + "/offsets");
ObjectMapper mapper = JacksonParser.getObjectMapper();
try {
ObjectNode node = mapper.createObjectNode();
node.put("Action", "open");
ArrayNode shardIds = mapper.createArrayNode();
for (String i : request.getShardIds()) {
shardIds.add(i);
}
node.put("ShardIds", shardIds);
req.setBody(mapper.writeValueAsString(node));
} catch (JsonGenerationException e) {
e.printStackTrace();
} catch (JsonMappingException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
return req;
}
private InitOffsetContextRequestJsonSer() {
}
private static InitOffsetContextRequestJsonSer instance;
public static InitOffsetContextRequestJsonSer getInstance() {
if (instance == null) {
instance = new InitOffsetContextRequestJsonSer();
}
return instance;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy