All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.aliyun.datahub.model.serialize.InitOffsetContextRequestJsonSer Maven / Gradle / Ivy

There is a newer version: 2.25.6
Show newest version
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