datahub.client.kafka.AvroSerializer Maven / Gradle / Ivy
package datahub.client.kafka;
import java.io.IOException;
import org.apache.avro.Schema;
import org.apache.avro.generic.GenericData;
import org.apache.avro.generic.GenericRecord;
import com.google.common.annotations.VisibleForTesting;
import com.linkedin.mxe.MetadataChangeProposal;
import datahub.event.EventFormatter;
import datahub.event.MetadataChangeProposalWrapper;
class AvroSerializer {
private final Schema _recordSchema;
private final Schema _genericAspectSchema;
private final EventFormatter _eventFormatter;
public AvroSerializer() throws IOException {
_recordSchema = new Schema.Parser()
.parse(this.getClass().getClassLoader().getResourceAsStream("MetadataChangeProposal.avsc"));
_genericAspectSchema = this._recordSchema.getField("aspect").schema().getTypes().get(1);
_eventFormatter = new EventFormatter(EventFormatter.Format.PEGASUS_JSON);
}
@VisibleForTesting
Schema getRecordSchema() {
return _recordSchema;
}
public GenericRecord serialize(@SuppressWarnings("rawtypes") MetadataChangeProposalWrapper mcpw) throws IOException {
return serialize(_eventFormatter.convert(mcpw));
}
public GenericRecord serialize(MetadataChangeProposal mcp) throws IOException {
GenericRecord genericRecord = new GenericData.Record(this._recordSchema);
genericRecord.put("entityUrn", mcp.getEntityUrn().toString());
GenericRecord genericAspect = new GenericData.Record(this._genericAspectSchema);
genericAspect.put("contentType", "application/json");
genericAspect.put("value", mcp.getAspect().getValue().asByteBuffer());
genericRecord.put("aspect", genericAspect);
genericRecord.put("aspectName", mcp.getAspectName());
genericRecord.put("entityType", mcp.getEntityType());
genericRecord.put("changeType", mcp.getChangeType());
return genericRecord;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy