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

com.aliyun.datahub.model.serialize.GetBlobRecordsResultJsonDeser 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.data.Field;
import com.aliyun.datahub.common.data.FieldType;
import com.aliyun.datahub.common.data.RecordType;
import com.aliyun.datahub.common.transport.Response;
import com.aliyun.datahub.common.util.JacksonParser;
import com.aliyun.datahub.exception.DatahubClientException;
import com.aliyun.datahub.exception.DatahubServiceException;
import com.aliyun.datahub.exception.MalformedRecordException;
import com.aliyun.datahub.model.*;
import org.codehaus.jackson.JsonNode;
import org.codehaus.jackson.map.ObjectMapper;

import java.io.IOException;
import java.util.*;

public class GetBlobRecordsResultJsonDeser implements Deserializer {
    @Override
    public GetBlobRecordsResult deserialize(GetBlobRecordsRequest request, Response response) throws DatahubClientException {
        if (!response.isOK()) {
            throw JsonErrorParser.getInstance().parse(response);
        }

        GetBlobRecordsResult rs = new GetBlobRecordsResult();
        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);
        }

        rs.setNextCursor(tree.get("NextCursor").asText());
        long sequence = tree.get("StartSeq").asLong();
        rs.setStartSeq(sequence);
        JsonNode recordsNode = tree.get("Records");

        List records = new ArrayList();
        Iterator itRecord = recordsNode.getElements();
        while (itRecord.hasNext()) {
            BlobRecordEntry entry = new BlobRecordEntry();
            JsonNode record = itRecord.next();
            JsonNode time = record.get("SystemTime");
            JsonNode data = record.get("Data");
            JsonNode attrs = record.get("Attributes");
            
            // sequence
            entry.setSequence(sequence++);
            
            // time
            entry.setSystemTime(time.asLong());

            // shard id
            entry.setShardId(request.getShardId());

            try {
                // record data
                entry.setData(data.getBinaryValue());
            } catch (IOException e) {
                throw new DatahubClientException("Decode record data failed:" + e.getMessage(), e);
            }

            // attributes
            if (attrs != null && !attrs.isNull()) {
                Iterator> itAttr = attrs.getFields();
                Map attrMap = new HashMap();
                while (itAttr.hasNext()) {
                    Map.Entry attr = itAttr.next();
                    entry.putAttribute(attr.getKey(), attr.getValue().asText());
                }
            }
            records.add(entry);
        }

        rs.setRecords(records);
        return rs;
    }

    private GetBlobRecordsResultJsonDeser() {

    }

    private static GetBlobRecordsResultJsonDeser instance;

    public static GetBlobRecordsResultJsonDeser getInstance() {
        if (instance == null)
            instance = new GetBlobRecordsResultJsonDeser();
        return instance;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy