/* * Copyright 2014-2015 the original author or authors. * * 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.rockagen.gnext.service.spring; import java.io.Serializable; import java.util.Collections; import java.util.List; import java.util.Map; import javax.annotation.Resource; import com.rockagen.commons.util.CommUtil; import com.rockagen.commons.util.ReflexUtil; import com.rockagen.gnext.dao.GenericDao; import com.rockagen.gnext.dao.Hibernate4GenericDao; import com.rockagen.gnext.dao.hb.Hibernate4GenericDaoImpl; import com.rockagen.gnext.qo.QueryObject; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.springframework.jdbc.datasource.lookup.DataSourceLookupFailureException; /** * Implementation of the <code>ObjectQueryGenericServ</code> interface * * @author RA * @see GenericServImpl */ public abstract class QueryObjectGenericServImpl<E, PK extends Serializable> extends GenericServImpl<E, QueryObject, PK> { @Resource private SessionFactory sessionFactory; @Override public List<?> query(final QueryObject queryObject) { if (queryObject == null) { return Collections.emptyList(); } Boolean limit = false; if (queryObject.getSize() > 0) { limit = true; } if (!CommUtil.isBlank(queryObject.getSql())) { if (limit) { if (notEmpty(queryObject.getMap())) { return getGenericDao().query( queryObject.getSql(), queryObject.getIndex(), queryObject.getSize(), queryObject.getMap()); } else { return getGenericDao().query( queryObject.getSql(), queryObject.getIndex(), queryObject.getSize(), queryObject.getArgs()); } } else { if (notEmpty(queryObject.getMap())) { return getGenericDao().query( queryObject.getSql(), queryObject.getMap()); } else { return getGenericDao().query( queryObject.getSql(), queryObject.getArgs()); } } } else if (queryObject.getDetachedCriteria() != null) { if (limit) { return getHibernate4GenericDao().queryByCriteria( queryObject.getDetachedCriteria(), queryObject.getIndex(), queryObject.getSize()); } else { return getHibernate4GenericDao().queryByCriteria( queryObject.getDetachedCriteria()); } } else { // XXX return Collections.emptyList(); } } private boolean notEmpty(Map e) { return e != null && !e.isEmpty(); } @Override public GenericDao<E, PK> getGenericDao() { return getHibernate4GenericDao(); } private Hibernate4GenericDao<E, PK> getHibernate4GenericDao() { return new Hibernate4GenericDaoImpl<E, PK>() { @Override protected Class<E> getEntityClass() { return obtainEntityClass(); } @Override protected Session getSession() { return obtainSession(); } }; } @SuppressWarnings("unchecked") protected Class<E> obtainEntityClass() { return (Class<E>) ReflexUtil.getSuperClassGenricClass(getClass(), 0); } /** * Get Session * * @return session */ private Session obtainSession() { if (sessionFactory == null) { throw new DataSourceLookupFailureException("sessionFactory must not be empty or null"); } return sessionFactory.getCurrentSession(); } }