/**
* TestCube is an enterprise Test management tool.
* Copyright (C) 2011 JatakaSource Ltd.
*
* it under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* TestCube is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with TestCube. If not, see <http://www.gnu.org/licenses/>.
*/
package org.jatakasource.testcube.dao.product;
import java.util.List;
import org.apache.commons.lang.StringUtils;
import org.hibernate.Criteria;
import org.hibernate.criterion.MatchMode;
import org.hibernate.criterion.Restrictions;
import org.jatakasource.common.dao.BaseHibernateDao;
import org.jatakasource.common.model.paging.Paging;
import org.jatakasource.common.model.paging.Sorting;
import org.jatakasource.testcube.dao.product.BuildDao;
import org.jatakasource.testcube.model.product.Build;
import org.jatakasource.testcube.model.product.IBuild;
import org.jatakasource.testcube.model.product.Product;
import org.springframework.stereotype.Repository;
@Repository
public class HibernateBuildDao extends BaseHibernateDao<IBuild, Long> implements BuildDao {
public HibernateBuildDao() {
super(Build.class);
}
@Override
public List<IBuild> findAll(Paging paging, Sorting sorting, String keyword) {
return findAll(paging, sorting, keyword);
}
@Override
@SuppressWarnings("unchecked")
public List<IBuild> findAll(Paging paging, Sorting sorting, String keyword, Long productId) {
Criteria criteria = getCurrentSession().createCriteria(Build.class);
if (StringUtils.isNotEmpty(keyword)) {
criteria.add(Restrictions.or(Restrictions.ilike(Build.FIELD_NAME, keyword.toLowerCase(), MatchMode.ANYWHERE),
Restrictions.ilike(Build.FIELD_DESC, keyword.toLowerCase(), MatchMode.ANYWHERE)));
}
if (productId != null) {
criteria.add(Restrictions.eq(Build.FIELD_PRODUCT + "." + Product.FIELD_ID, productId));
}
addPaging(criteria, paging);
addSorting(criteria, sorting);
return criteria.list();
}
}