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

com.qubole.presto.kinesis.decoder.KinesisFieldDecoder Maven / Gradle / Ivy

The newest version!
/*
 * 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.qubole.presto.kinesis.decoder;

import java.util.Set;

import com.qubole.presto.kinesis.KinesisColumnHandle;
import com.qubole.presto.kinesis.KinesisFieldValueProvider;

public interface KinesisFieldDecoder
{
    /**
     * Default name. Each decoder type *must* have a default decoder as fallback.
     */
    String DEFAULT_FIELD_DECODER_NAME = "_default";

    /**
     * Returns the types which the field decoder can process.
     *
     * @return  Returns the types which the field decoder can process
     */
    Set> getJavaTypes();

    /**
     * Returns the name of the row decoder to which this field decoder belongs.
     *
     * @return Returns the name of the row decoder to which this field decoder belongs
     */
    String getRowDecoderName();

    /**
     * Returns the field decoder specific name. This name will be selected with the stream description value.
     *
     * @return Returns the field decoder specific name.
     */
    String getFieldDecoderName();

    /**
     * Decode a value for the given column handle.
     *
     * @param value The raw value as generated by the row decoder.
     * @param columnHandle The column for which the value is decoded.
     * @return A {@link KinesisFieldDecoder} instance which returns a captured value for this specific column.
     */
    KinesisFieldValueProvider decode(T value, KinesisColumnHandle columnHandle);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy