mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
97 lines
3.5 KiB
Java
Executable File
97 lines
3.5 KiB
Java
Executable File
/**
|
|
* 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 <http://www.gnu.org/licenses/>.
|
|
*
|
|
*/
|
|
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<UserVmVO, Long> {
|
|
List<UserVmVO> listByAccountId(long id);
|
|
|
|
List<UserVmVO> listByAccountAndPod(long accountId, long podId);
|
|
List<UserVmVO> listByAccountAndDataCenter(long accountId, long dcId);
|
|
List<UserVmVO> listByHostId(Long hostId);
|
|
List<UserVmVO> 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<UserVmVO> 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<UserVmVO> findDestroyedVms(Date date);
|
|
|
|
/**
|
|
* Find all vms that use a domain router
|
|
* @param routerId
|
|
* @return
|
|
*/
|
|
List<UserVmVO> listByRouterId(long routerId);
|
|
|
|
/**
|
|
* List running VMs on the specified host
|
|
* @param id
|
|
* @return
|
|
*/
|
|
public List<UserVmVO> 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<UserVmVO> listVirtualNetworkInstancesByAcctAndZone(long accountId, long dcId);
|
|
|
|
List<UserVmVO> listVmsUsingGuestIpAddress(long dcId, String ipAddress);
|
|
|
|
UserVm findByZoneAndAcctAndGuestIpAddress(long zoneId, long accountId, String ipAddress);
|
|
}
|