/** * Copyright (C) 2010 Cloud.com, Inc. All rights reserved. * * This software is licensed under the GNU General Public License v3 or later. * * It is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or any later version. * This program 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 General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * */ package com.cloud.vm.dao; import java.util.Date; import java.util.List; import com.cloud.uservm.UserVm; import com.cloud.utils.db.GenericDao; import com.cloud.vm.State; import com.cloud.vm.UserVmVO; import com.cloud.vm.VirtualMachine; public interface UserVmDao extends GenericDao { List listByAccountId(long id); List listByAccountAndPod(long accountId, long podId); List listByAccountAndDataCenter(long accountId, long dcId); List listByHostId(Long hostId); List listUpByHostId(Long hostId); /** * Find vms under the same router in the state. * @param routerId id of the router. * @param state state that it's in. * @return list of userVmVO */ List listBy(long routerId, State... state); UserVmVO findByName(String name); /** * This method is of supreme importance in the management of VMs. It updates a uservm if and only if * the following condition are true. If the update is complete, all changes to the uservm entity * are persisted. The state is also changed to the new state. * * 1. There's a transition from the current state via the event to a new state. * 2. The db has not changed on the current state, update time, and host id sent. * * @param vm vm object to persist. * @param event * @param hostId * @return true if updated, false if not. */ //boolean updateIf(UserVmVO vm, VirtualMachine.Event event, Long hostId); /** * Updates display name and group for vm; enables/disables ha * @param id vm id. * @param displan name and enable for ha */ void updateVM(long id, String displayName, boolean enable); List findDestroyedVms(Date date); /** * Find all vms that use a domain router * @param routerId * @return */ List listByRouterId(long routerId); /** * List running VMs on the specified host * @param id * @return */ public List listRunningByHostId(long hostId); /** * List user vm instances with virtualized networking (i.e. not direct attached networking) for the given account and datacenter * @param accountId will search for vm instances belonging to this account * @param dcId will search for vm instances in this zone * @return the list of vm instances owned by the account in the given data center that have virtualized networking (not direct attached networking) */ List listVirtualNetworkInstancesByAcctAndZone(long accountId, long dcId); List listVmsUsingGuestIpAddress(long dcId, String ipAddress); UserVm findByZoneAndAcctAndGuestIpAddress(long zoneId, long accountId, String ipAddress); }