/**
* Abiquo community edition
* cloud management application for hybrid clouds
* Copyright (C) 2008-2010 - Abiquo Holdings S.L.
*
* This application is free software; you can redistribute it and/or
* modify it under the terms of the GNU LESSER GENERAL PUBLIC
* LICENSE as published by the Free Software Foundation under
* version 3 of the License
*
* This software 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 v.3 for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the
* Free Software Foundation, Inc., 59 Temple Place - Suite 330,
* Boston, MA 02111-1307, USA.
*/
package com.abiquo.abiserver.persistence.dao.virtualappliance.hibernate;
import java.util.Collection;
import java.util.List;
import org.hibernate.Query;
import com.abiquo.abiserver.business.hibernate.pojohb.virtualappliance.VirtualApplianceConversionsHB;
import com.abiquo.abiserver.business.hibernate.pojohb.virtualappliance.VirtualappHB;
import com.abiquo.abiserver.persistence.dao.virtualappliance.VirtualApplianceConversionsDAO;
import com.abiquo.abiserver.persistence.hibernate.HibernateDAO;
/**
* Class that implements the extra DAO functions for the
* {@link com.abiquo.abiserver.persistence.dao.virtualappliance.VirtualApplianceConversionsDAO}
* interface
*
* @author dcalavera@abiquo.com
*/
public class VirtualApplianceConversionsDAOHibernate extends
HibernateDAO<VirtualApplianceConversionsHB, Integer> implements VirtualApplianceConversionsDAO
{
@Override
public List<VirtualApplianceConversionsHB> findByConversion(final int idConversion)
{
Query query =
getSession()
.createQuery(
"from com.abiquo.abiserver.business.hibernate.pojohb.virtualappliance.VirtualApplianceConversionsHB where virtualImageConversion.id = :id");
query.setParameter("id", idConversion);
return query.list();
}
@Override
public Collection<VirtualappHB> findByPendingAppliances(final int idPending,
final Collection<Integer> appliances)
{
return getSession()
.createQuery(
"select va from VirtualappExtendedHB va, com.abiquo.abiserver.business.hibernate.pojohb.virtualappliance.VirtualApplianceConversionsHB vac where va.idVirtualApp = vac.virtualAppliance.id and vac.virtualAppliance.id in (:appliances) and vac.id != :idPending")
.setParameterList("appliances", appliances).setParameter("idPending", idPending).list();
}
@Override
public void makeTransientByVirtualAppliance(final int idVirtualAppliance)
{
getSession()
.createQuery(
"delete com.abiquo.abiserver.business.hibernate.pojohb.virtualappliance.VirtualApplianceConversionsHB vac where vac.virtualAppliance.id = :idAppliance")
.setParameter("idAppliance", idVirtualAppliance).executeUpdate();
}
@Override
public String findDatacenterUUIDByVASConversion(final int idVASC)
{
Query query =
getSession()
.createSQLQuery(
"select distinct(dc.uuid) from vappstateful_conversions vasc left outer join virtualapp va on vasc.idVirtualApp = va.idVirtualApp left outer join virtualdatacenter vdc on va.idVirtualDataCenter = vdc.idVirtualdataCenter left outer join datacenter dc on vdc.idDatacenter = dc.idDataCenter where vasc.id = :id");
query.setParameter("id", idVASC);
return (String) query.uniqueResult();
}
}