com.impetus.client.cassandra.thrift.ThriftDataResultHelper Maven / Gradle / Ivy
/**
* 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
© 2015 - 2025 Weber Informatics LLC | Privacy Policy