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

com.hurence.logisland.serializer.SerializerProvider Maven / Gradle / Ivy

There is a newer version: 1.4.1
Show newest version
/**
 * Copyright (C) 2016 Hurence ([email protected])
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *         http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package com.hurence.logisland.serializer;

import com.hurence.logisland.logging.ComponentLog;
import com.hurence.logisland.logging.LogLevel;
import com.hurence.logisland.logging.StandardComponentLogger;
import org.apache.avro.Schema;

public class SerializerProvider {


    private static ComponentLog logger = new StandardComponentLogger("serializerProvider", SerializerProvider.class);
    private static String AVRO_SERIALIZER = AvroSerializer.class.getName();
    private static String JSON_SERIALIZER = JsonSerializer.class.getName();
    private static String EXTENDED_JSON_SERIALIZER = ExtendedJsonSerializer.class.getName();


    private static String KRYO_SERIALIZER = KryoSerializer.class.getName();
    private static String BYTES_ARRAY_SERIALIZER = BytesArraySerializer.class.getName();
    private static String STRING_SERIALIZER = StringSerializer.class.getName();
    private static String NOOP_SERIALIZER = NoopSerializer.class.getName();

    private static String KURA_PROTOBUF_SERIALIZER = KuraProtobufSerializer.class.getName();

    /**
     * build a serializer
     *
     * @param inSerializerClass the serializer type
     * @param schemaContent     an optional Avro schema
     * @return the serializer
     */
    public static RecordSerializer getSerializer(final String inSerializerClass, final String schemaContent) {

        try {
            if (inSerializerClass.equals(AVRO_SERIALIZER)) {
                Schema.Parser parser = new Schema.Parser();
                Schema schema = parser.parse(schemaContent);
                return new AvroSerializer(schema);
            } else if (inSerializerClass.equals(JSON_SERIALIZER)) {
                return new JsonSerializer();
            } else if (inSerializerClass.equals(EXTENDED_JSON_SERIALIZER)) {
                return new ExtendedJsonSerializer(schemaContent);
            } else if (inSerializerClass.equals(KRYO_SERIALIZER)) {
                return new KryoSerializer(true);
            } else if (inSerializerClass.equals(BYTES_ARRAY_SERIALIZER)) {
                return new BytesArraySerializer();
            } else if (inSerializerClass.equals(KURA_PROTOBUF_SERIALIZER)) {
                return new KuraProtobufSerializer();
            } else if (inSerializerClass.equals(STRING_SERIALIZER)) {
                return new StringSerializer();
            } else {
                return new NoopSerializer();
            }
        } catch (Exception e) {
            logger.log(LogLevel.ERROR, e.toString());
            return new NoopSerializer();
        }

    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy