Java tutorial
//////////////////////////////////////////////////////////////////////// // // Copyright (c) 2009-2015 Denim Group, Ltd. // // The contents of this file are subject to the Mozilla Public 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.mozilla.org/MPL/ // // Software distributed under the License is distributed on an "AS IS" // basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the // License for the specific language governing rights and limitations // under the License. // // The Original Code is ThreadFix. // // The Initial Developer of the Original Code is Denim Group, Ltd. // Portions created by Denim Group, Ltd. are Copyright (C) // Denim Group, Ltd. All Rights Reserved. // // Contributor(s): Denim Group, Ltd. // //////////////////////////////////////////////////////////////////////// package com.denimgroup.threadfix.data.dao.hibernate; import com.denimgroup.threadfix.data.dao.AbstractObjectDao; import com.denimgroup.threadfix.data.dao.ApplicationChannelDao; import com.denimgroup.threadfix.data.entities.ApplicationChannel; import com.denimgroup.threadfix.data.entities.Scan; import org.hibernate.Criteria; import org.hibernate.SessionFactory; import org.hibernate.criterion.Order; import org.hibernate.criterion.Projections; import org.hibernate.criterion.Restrictions; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Repository; import java.util.Calendar; import java.util.List; /** * Hibernate Channel DAO implementation. Most basic methods are implemented in * the AbstractGenericDao * * @author mcollins, dwolf * @see AbstractObjectDao */ @Repository public class HibernateApplicationChannelDao extends AbstractObjectDao<ApplicationChannel> implements ApplicationChannelDao { @Autowired public HibernateApplicationChannelDao(SessionFactory sessionFactory) { super(sessionFactory); } @Override @SuppressWarnings("unchecked") public List<ApplicationChannel> retrieveAll() { return getActiveChannelCriteria().createAlias("channelType", "ct").createAlias("application", "app") .createAlias("application.organization", "org").addOrder(Order.asc("org.name")) .addOrder(Order.asc("app.name")).addOrder(Order.asc("ct.name")).list(); } @Override protected Class<ApplicationChannel> getClassReference() { return ApplicationChannel.class; } @Override public ApplicationChannel retrieveByAppIdAndChannelId(Integer appId, Integer channelId) { return (ApplicationChannel) getActiveChannelCriteria().createAlias("channelType", "ct") .createAlias("application", "app").add(Restrictions.eq("ct.id", channelId)) .add(Restrictions.eq("app.id", appId)).uniqueResult(); } private Criteria getActiveChannelCriteria() { return sessionFactory.getCurrentSession().createCriteria(ApplicationChannel.class) .add(Restrictions.eq("active", true)); } @Override public Calendar getMostRecentQueueScanTime(Integer channelId) { return (Calendar) sessionFactory.getCurrentSession() .createQuery("select scanDate from JobStatus status " + "where applicationChannel = :channelId and hasStartedProcessing is false " + "order by scanDate desc") .setInteger("channelId", channelId).setMaxResults(1).uniqueResult(); } @Override public Calendar getMostRecentScanTime(Integer channelId) { return (Calendar) sessionFactory.getCurrentSession().createCriteria(Scan.class) .addOrder(Order.desc("importTime")).setProjection(Projections.property("importTime")) .setMaxResults(1).uniqueResult(); } }