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

info.archinnov.achilles.dao.ThriftGenericEntityDao Maven / Gradle / Ivy

package info.archinnov.achilles.dao;

import static info.archinnov.achilles.serializer.ThriftSerializerUtils.*;
import info.archinnov.achilles.consistency.AchillesConsistencyLevelPolicy;
import org.apache.cassandra.utils.Pair;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import me.prettyprint.hector.api.Cluster;
import me.prettyprint.hector.api.Keyspace;
import me.prettyprint.hector.api.beans.AbstractComposite.ComponentEquality;
import me.prettyprint.hector.api.beans.Composite;
import me.prettyprint.hector.api.beans.HColumn;
import me.prettyprint.hector.api.beans.Row;
import me.prettyprint.hector.api.beans.Rows;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * ThriftGenericEntityDao
 * 
 * @author DuyHai DOAN
 * 
 */
public class ThriftGenericEntityDao extends ThriftAbstractDao
{
	private static final Logger log = LoggerFactory.getLogger(ThriftGenericEntityDao.class);

	protected static final byte[] START_EAGER = new byte[]
	{
		0
	};
	protected static final byte[] END_EAGER = new byte[]
	{
		20
	};

	private Composite startCompositeForEagerFetch;
	private Composite endCompositeForEagerFetch;

	protected ThriftGenericEntityDao() {
		this.initComposites();
	}

	protected  ThriftGenericEntityDao(Pair rowkeyAndValueClasses) {
		this.initComposites();
		super.rowkeyAndValueClasses = rowkeyAndValueClasses;
	}

	public  ThriftGenericEntityDao(Cluster cluster, Keyspace keyspace, String cf,
			AchillesConsistencyLevelPolicy consistencyPolicy, Pair rowkeyAndValueClasses)
	{
		super(cluster, keyspace, cf, consistencyPolicy, rowkeyAndValueClasses);
		this.initComposites();
		columnNameSerializer = COMPOSITE_SRZ;
		log
				.debug("Initializing GenericEntityDao for key serializer '{}', composite comparator and value serializer '{}'",
						this.rowSrz().getComparatorType().getTypeName(), STRING_SRZ
								.getComparatorType()
								.getTypeName());

	}

	public  List> eagerFetchEntity(K key)
	{
		log.trace("Eager fetching properties for column family {} ", columnFamily);

		return this.findColumnsRange(key, startCompositeForEagerFetch, endCompositeForEagerFetch,
				false, Integer.MAX_VALUE);
	}

	public  Map>> eagerFetchEntities(List keys)
	{
		log.trace("Eager fetching properties for multiple entities in column family {} ",
				columnFamily);

		Map>> map = new HashMap>>();

		Rows rows = this.multiGetSliceRange(keys,
				startCompositeForEagerFetch, endCompositeForEagerFetch, false, Integer.MAX_VALUE);

		for (Row row : rows)
		{
			List> columns = new ArrayList>();
			for (HColumn column : row.getColumnSlice().getColumns())
			{
				columns.add(Pair.create(column.getName(), column.getValue()));
			}

			map.put(row.getKey(), columns);
		}

		return map;
	}

	private void initComposites()
	{
		startCompositeForEagerFetch = new Composite();
		startCompositeForEagerFetch.addComponent(0, START_EAGER, ComponentEquality.EQUAL);

		endCompositeForEagerFetch = new Composite();
		endCompositeForEagerFetch.addComponent(0, END_EAGER, ComponentEquality.GREATER_THAN_EQUAL);
	}
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy