This repository has been archived on 2024-05-07. You can view files and clone it, but cannot push or open issues or pull requests.
species-discovery/src/main/java/org/gcube/portlets/user/speciesdiscovery/server/persistence/TaxonomyRowBuffer.java

217 lines
7.0 KiB
Java

/**
*
*/
package org.gcube.portlets.user.speciesdiscovery.server.persistence;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.Query;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
import org.gcube.portlets.user.speciesdiscovery.server.persistence.dao.AbstractPersistence;
import org.gcube.portlets.user.speciesdiscovery.server.session.FilterableFetchingBuffer;
import org.gcube.portlets.user.speciesdiscovery.shared.MainTaxonomicRankEnum;
import org.gcube.portlets.user.speciesdiscovery.shared.ResultRow;
import org.gcube.portlets.user.speciesdiscovery.shared.TaxonomyRow;
import org.gcube.portlets.user.speciesdiscovery.shared.filter.FilterCriteria;
import org.gcube.portlets.user.speciesdiscovery.shared.filter.ResultFilter;
import org.gcube.portlets.user.speciesdiscovery.shared.util.NormalizeString;
/**
*
* @author Francesco Mangiacrapa francesco.mangiacrapa@isti.cnr.it
*
*/
public class TaxonomyRowBuffer extends AbstractSelectableDaoBuffer<TaxonomyRow> implements FilterableFetchingBuffer<TaxonomyRow> {
private int filteredListSize = 0;
public TaxonomyRowBuffer(AbstractPersistence<TaxonomyRow> dao) {
super(dao, TaxonomyRow.ID_FIELD, TaxonomyRow.SELECTED);
}
/**
* {@inheritDoc}
* @throws Exception
*/
@Override
public void add(TaxonomyRow row) throws Exception
{
//DEBUG
logger.trace("Add item "+ row.getId() + " service id: " +row.getServiceId());
// logger.trace("Add item "+ row);
super.add(row);
}
@Override
public List<TaxonomyRow> getFilteredList(FilterCriteria filterCriteria) throws SQLException {
ResultFilter activeFiltersObject = (ResultFilter) filterCriteria;
List<TaxonomyRow> list = new ArrayList<TaxonomyRow>();
Iterator<TaxonomyRow> iterator = null;
// QueryBuilder<TaxonomyRow, Integer> queryBuilder = dao.queryBuilder();
String value;
if(activeFiltersObject!=null){
//FILTER BY CLASSIFICATION
if(activeFiltersObject.isByClassification()){
int counter = activeFiltersObject.getNumberOfData();
String columName = null;
if(activeFiltersObject.getRankClassification().compareTo(MainTaxonomicRankEnum.KINGDOM.getLabel())==0)
columName = TaxonomyRow.KINGDOM_ID;
else if(activeFiltersObject.getRankClassification().compareTo(MainTaxonomicRankEnum.FAMILY.getLabel())==0)
columName = TaxonomyRow.FAMILY_ID;
else if(activeFiltersObject.getRankClassification().compareTo(MainTaxonomicRankEnum.GENUS.getLabel())==0)
columName = TaxonomyRow.GENUS_ID;
else if(activeFiltersObject.getRankClassification().compareTo(MainTaxonomicRankEnum.CLASS.getLabel())==0)
columName = TaxonomyRow.CLASS_ID;
else if(activeFiltersObject.getRankClassification().compareTo(MainTaxonomicRankEnum.ORDER.getLabel())==0)
columName = TaxonomyRow.ORDER_ID;
else if(activeFiltersObject.getRankClassification().compareTo(MainTaxonomicRankEnum.PHYLUM.getLabel())==0)
columName = TaxonomyRow.PHYLUM_ID;
else if(activeFiltersObject.getRankClassification().compareTo(MainTaxonomicRankEnum.SPECIES.getLabel())==0)
columName = TaxonomyRow.SPECIES_ID;
//
// logger.trace("in classification filter - columName: "+columName);
try {
CriteriaBuilder queryBuilder = dao.getCriteriaBuilder();
Query query = dao.createNewManager().createQuery("select r FROM TaxonomyRow r where r."+columName+ "='"+activeFiltersObject.getClassificationId()+"'");
//
query.setMaxResults(counter);
iterator = query.getResultList().iterator();
// logger.trace("in classification filter - statement: "+queryBuilder.where().eq(columName, activeFiltersObject.getClassificationId()).getStatement());
} catch (Exception e) {
logger.error("Error in activeFiltersObject.isByClassification(): "+e, e);
e.printStackTrace();
}
//FILTER BY DATA PROVIDER
}else if(activeFiltersObject.isByDataProvider()){
try {
CriteriaBuilder queryBuilder = dao.getCriteriaBuilder();
value = activeFiltersObject.getDataProviderName();
CriteriaQuery<Object> cq = queryBuilder.createQuery();
Predicate pr1 = queryBuilder.equal(dao.rootFrom(cq).get(TaxonomyRow.DATAPROVIDER_NAME), value);
cq.where(pr1);
//TODO FIXME empty value
logger.trace("FILTER BY DATA PROVIDER: "+ value );
iterator = dao.executeCriteriaQuery(cq).iterator();
} catch (Exception e) {
logger.error("Error in activeFiltersObject.isByDataProvider(): "+e, e);
e.printStackTrace();
}
//FILTER BY DATA SOURCE
}else if(activeFiltersObject.isByDataSourceName()){
try {
CriteriaBuilder queryBuilder = dao.getCriteriaBuilder();
value = activeFiltersObject.getDataSourceName();
CriteriaQuery<Object> cq = queryBuilder.createQuery();
Predicate pr1 = queryBuilder.equal(dao.rootFrom(cq).get(TaxonomyRow.DATAPROVIDER_NAME), value);
cq.where(pr1);
//TODO FIXME empty value
logger.trace("FILTER BY DATA SOURCE: "+ value );
iterator = dao.executeCriteriaQuery(cq).iterator();
} catch (Exception e) {
logger.error("Error in activeFiltersObject.isByDataProvider(): "+e, e);
e.printStackTrace();
}
// //FILTER BY RANK
}else if(activeFiltersObject.isByRank()){
try {
CriteriaBuilder queryBuilder = dao.getCriteriaBuilder();
value = activeFiltersObject.getRankName();
// value = NormalizeString.lowerCaseUpFirstChar(activeFiltersObject.getRankName());
logger.trace("in rank filter - value: "+value);
CriteriaQuery<Object> cq = queryBuilder.createQuery();
Predicate pr1 = queryBuilder.equal(dao.rootFrom(cq).get(TaxonomyRow.RANK), NormalizeString.validateUndefined(value));
cq.where(pr1);
logger.trace("FILTER BY RANK: "+ value );
iterator = dao.executeCriteriaQuery(cq).iterator();
} catch (Exception e) {
logger.error("Error in activeFiltersObject.isByRank(): "+e, e);
}
}
if(iterator!=null){
while(iterator.hasNext()){
TaxonomyRow row = iterator.next();
list.add(row);
}
filteredListSize = list.size();
}
}
logger.trace("RETURNED List size " + list.size());
return list;
}
@Override
public int getFilteredListSize() throws SQLException {
// return 0;
return filteredListSize;
}
@Override
public void updateAllSelection(boolean selection) throws Exception {
EntityManager em = dao.createNewManager();
//TODO generalize?
String queryString = "UPDATE TaxonomyRow SET "
+ ResultRow.SELECTED + " = "+ selection
+" where "+TaxonomyRow.IS_PARENT +"=false";
try {
em.getTransaction().begin();
int updateCount = em.createQuery(queryString).executeUpdate();
logger.trace("Updated " + updateCount + " item");
em.getTransaction().commit();
} finally {
if (em.getTransaction().isActive())
em.getTransaction().rollback();
em.close();
}
}
}