com.flipkart.hbaseobjectmapper.codec.Codec Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hbase-object-mapper Show documentation
Show all versions of hbase-object-mapper Show documentation
HBase ORM is a light-weight, thread-safe and performant library that enables:
[1] object-oriented access of HBase rows (Data Access Object) with minimal code and good testability
[2] reading from and/or writing to HBase tables in Hadoop MapReduce jobs
package com.flipkart.hbaseobjectmapper.codec;
import java.io.Serializable;
import java.lang.reflect.Type;
import java.util.Map;
/**
* Interface that defines serialization and deserialization behavior for {@link com.flipkart.hbaseobjectmapper.HBObjectMapper HBObjectMapper}
*/
public interface Codec {
/**
* Serialize object to a byte[]
*
* @param object Object to be serialized
* @param flags Flags for tuning serialization behavior
* @return byte array - this would be used 'as is' in setting the column value in HBase row
* @throws SerializationException If serialization fails (e.g. when input object
has a field of data type that isn't serializable by this codec)
*/
byte[] serialize(Serializable object, Map flags) throws SerializationException;
/**
* Deserialize byte[]
into an object
*
* @param bytes byte array that needs to be deserialized
* @param flags Flags for tuning deserialization behavior
* @param type Java type to which this byte[]
needs to be deserialized to
* @return Object
* @throws DeserializationException If deserialization fails (e.g. malformed string or definition of a data type used isn't available at runtime)
*/
Serializable deserialize(byte[] bytes, Type type, Map flags) throws DeserializationException;
/**
* Check whether a specific type can be deserialized using this codec
*
* @param type Java type
* @return true
or false
*/
boolean canDeserialize(Type type);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy