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

com.impetus.client.cassandra.thrift.ThriftDataResultHelper Maven / Gradle / Ivy

There is a newer version: 3.13
Show newest version
/**
 * Copyright 2012 Impetus Infotech.
 *
 * 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.impetus.client.cassandra.thrift;

import java.lang.reflect.Field;
import java.nio.ByteBuffer;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.cassandra.thrift.ColumnOrSuperColumn;
import org.apache.cassandra.thrift.KeySlice;

import com.impetus.kundera.metadata.model.EntityMetadata;
import com.impetus.kundera.metadata.model.EntityMetadata.Type;
import com.impetus.kundera.property.PropertyAccessor;
import com.impetus.kundera.property.PropertyAccessorFactory;


/**
 * Provides utility methods for extracting useful data from Thrift result
 * retrieved from database (usually in the form of {@link ColumnOrSuperColumn}.
 *
 * @author amresh.singh
 */
public class ThriftDataResultHelper
{
    
    /**
     * The Enum ColumnFamilyType.
     */
    public enum ColumnFamilyType
    {
        
        /** The column. */
        COLUMN, /* Column family */
        /** The super column. */
        SUPER_COLUMN, /* Super Column family */
        /** The counter column. */
        COUNTER_COLUMN, /* Counter Column family */
        /** The counter super column. */
        COUNTER_SUPER_COLUMN
        /* Super Counter Column family */
    }

    /**
     * Transforms data retrieved as result via thrift to a List whose content
     * type is determined by {@link ColumnFamilyType}.
     *
     * @param  the generic type
     * @param coscList the cosc list
     * @param columnFamilyType the column family type
     * @param row the row
     * @return the list
     */
    public static  List transformThriftResult(List coscList,
            ColumnFamilyType columnFamilyType, ThriftRow row)
    {
        List result = new ArrayList(coscList.size());
        for (ColumnOrSuperColumn cosc : coscList)
        {
            result.add(transformThriftResult(cosc, columnFamilyType, row));
        }
        return result;
    }

    /**
     * Transform thrift result.
     *
     * @param  the generic type
     * @param cosc the cosc
     * @param columnFamilyType the column family type
     * @param row the row
     * @return the t
     */
    public static  T transformThriftResult(ColumnOrSuperColumn cosc, ColumnFamilyType columnFamilyType, ThriftRow row)
    {
        Object output = null;
        if (cosc != null)
        {
            switch (columnFamilyType)
            {
            case COLUMN:
                output = cosc.column;
                if (row != null)
                {
                    row.addColumn(cosc.column);
                }
                break;

            case SUPER_COLUMN:
                output = cosc.super_column;
                if (row != null)
                {
                    row.addSuperColumn(cosc.super_column);
                }
                break;

            case COUNTER_COLUMN:
                output = cosc.counter_column;
                if (row != null)
                {
                    row.addCounterColumn(cosc.counter_column);
                }
                break;

            case COUNTER_SUPER_COLUMN:
                output = cosc.counter_super_column;
                if (row != null)
                {
                    row.addCounterSuperColumn(cosc.counter_super_column);
                }
                break;
            }
        }
        return (T) output;
    }

    /**
     * Transforms data retrieved as result via thrift to a Map whose content
     * type is determined by {@link ColumnFamilyType}.
     *
     * @param  the generic type
     * @param coscResultMap the cosc result map
     * @param columnFamilyType the column family type
     * @param row the row
     * @return the map
     */
    public static  Map> transformThriftResult(
            Map> coscResultMap, ColumnFamilyType columnFamilyType, ThriftRow row)
    {

        Map> output = new HashMap>();

        for (ByteBuffer key : coscResultMap.keySet())
        {
            output.put(key, (List) transformThriftResult(coscResultMap.get(key), columnFamilyType, row));
        }

        return output;
    }

    /**
     * Transform thrift result.
     *
     * @param  the generic type
     * @param columnFamilyType the column family type
     * @param keySlices the key slices
     * @param row the row
     * @return the map
     */
    public static  Map> transformThriftResult(ColumnFamilyType columnFamilyType,
            List keySlices, ThriftRow row)
    {

        Map> output = new HashMap>();

        for (KeySlice keySlice : keySlices)
        {
            output.put(ByteBuffer.wrap(keySlice.getKey()),
                    (List) transformThriftResult(keySlice.getColumns(), columnFamilyType, row));
        }

        return output;
    }

    /**
     * Transforms data retrieved as result via thrift to a List whose content
     * type is determined by {@link ColumnFamilyType}.
     *
     * @param  the generic type
     * @param coscResultMap the cosc result map
     * @param columnFamilyType the column family type
     * @param row the row
     * @return the list
     */
    public  List transformThriftResultAndAddToList(Map> coscResultMap,
            ColumnFamilyType columnFamilyType, ThriftRow row)
    {

        List coscList = new ArrayList();

        for (List list : coscResultMap.values())
        {
            coscList.addAll(list);
        }

        return transformThriftResult(coscList, columnFamilyType, row);
    }

    /**
     * Translates into thrift row.
     *
     * @param coscResultMap the cosc result map
     * @param isCounterType the is counter type
     * @param columnFamilyType the column family type
     * @param row the row
     * @return the thrift row
     */
    public ThriftRow translateToThriftRow(Map> coscResultMap,
            boolean isCounterType, Type columnFamilyType, ThriftRow row)
    {
        ColumnFamilyType columnType = ColumnFamilyType.COLUMN;

        if (isCounterType)
        {
            if (columnFamilyType.equals(Type.SUPER_COLUMN_FAMILY))
            {
                columnType = ColumnFamilyType.COUNTER_SUPER_COLUMN;
            }
            else
            {
                columnType = ColumnFamilyType.COUNTER_COLUMN;
            }
        }
        else if (columnFamilyType.equals(Type.SUPER_COLUMN_FAMILY))
        {
            columnType = ColumnFamilyType.SUPER_COLUMN;
        }
        transformThriftResultAndAddToList(coscResultMap, columnType, row);
        return row;
    }

    /**
     * Fetches Row keys from a {@link List} of {@link KeySlice}.
     *
     * @param keySlices the key slices
     * @param metadata the metadata
     * @return the row keys
     */
    public static List getRowKeys(List keySlices, EntityMetadata metadata)
    {
        PropertyAccessor accessor = PropertyAccessorFactory.getPropertyAccessor((Field) metadata.getIdAttribute()
                .getJavaMember());
        List rowKeys = new ArrayList();
        for (KeySlice keySlice : keySlices)
        {
            byte[] key = keySlice.getKey();
            Object rowKey = accessor.fromBytes(metadata.getIdAttribute().getJavaType(), key);
            rowKeys.add(rowKey);
        }
        return rowKeys;
    }

}