Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
io.cloudslang.content.vmware.services.utils.VmConfigSpecs Maven / Gradle / Ivy
/*
* (c) Copyright 2017 EntIT Software LLC, a Micro Focus company, L.P.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Apache License v2.0 which accompany this distribution.
*
* The Apache License is available at
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.cloudslang.content.vmware.services.utils;
import com.vmware.vim25.*;
import io.cloudslang.content.vmware.connection.ConnectionResources;
import io.cloudslang.content.vmware.constants.Constants;
import io.cloudslang.content.vmware.constants.ErrorMessages;
import io.cloudslang.content.vmware.entities.ManagedObjectType;
import io.cloudslang.content.vmware.entities.Operation;
import io.cloudslang.content.vmware.entities.VmInputs;
import io.cloudslang.content.vmware.services.helpers.MorObjectHandler;
import io.cloudslang.content.vmware.utils.InputUtils;
import org.apache.commons.lang3.StringUtils;
import org.jetbrains.annotations.NotNull;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
/**
* Created by Mihai Tusa.
* 1/8/2016.
*/
public class VmConfigSpecs {
private static final String GENERATED = "generated";
private static final String CONFIG_HARDWARE_DEVICE = "config.hardware.device";
private static final String DEFAULT_FLOPPY_DEVICE_NAME = "/dev/fd0";
private static final String DEFAULT_VOLUME_NAME = "[Local]";
private static final String LEFT_SQUARE_BRACKET = "[";
private static final int DEFAULT_DISK_CONTROLLER_KEY = 1;
private static final int DEFAULT_DISK_UNIT_NUMBER = 0;
private static final int DEFAULT_DISK_KEY = 0;
private static final int DEFAULT_FLOPPY_DEVICE_KEY = 3;
private static final int DEFAULT_CD_ROM_KEY = 20;
private static final int DEFAULT_CD_ROM_UNIT_NUMBER = 0;
private static final int DEFAULT_CONTROLLER_BUS_NUMBER = 0;
private static final int DEFAULT_NIC_KEY = 4;
private static final int MAXIMUM_SCSI_SLOTS = 16;
private static final int MAXIMUM_ATAPI_SLOTS = 2;
private static final int RESERVED_SCSI_SLOT = 7;
private static final int SERVER_ASSIGNED = -1;
private static final int OCCUPIED = 1;
public VirtualMachineConfigSpec getVmConfigSpec(VmInputs vmInputs, ConnectionResources connectionResources) throws Exception {
VmUtils vmUtils = new VmUtils();
VirtualMachineConfigSpec vmConfigSpec = createVmConfigSpec(connectionResources, vmInputs);
vmConfigSpec = vmUtils.getPopulatedVmConfigSpec(vmConfigSpec, vmInputs, vmInputs.getVirtualMachineName());
return vmConfigSpec;
}
public VirtualMachineCloneSpec getCloneSpec(VmInputs vmInputs, VirtualMachineRelocateSpec virtualMachineRelocateSpec)
throws Exception {
VirtualMachineCloneSpec cloneSpec = new VirtualMachineCloneSpec();
cloneSpec.setLocation(virtualMachineRelocateSpec);
cloneSpec.setPowerOn(false);
cloneSpec.setTemplate(vmInputs.isTemplate());
VmUtils vmUtils = new VmUtils();
VirtualMachineConfigSpec vmConfigSpec = vmUtils.getPopulatedVmConfigSpec(new VirtualMachineConfigSpec(),
vmInputs, vmInputs.getCloneName());
ResourceAllocationInfo resourceAllocationInfo = getResourceAllocationInfo(SharesLevel.NORMAL.value());
vmConfigSpec.setMemoryAllocation(resourceAllocationInfo);
vmConfigSpec.setCpuAllocation(resourceAllocationInfo);
cloneSpec.setConfig(vmConfigSpec);
return cloneSpec;
}
VirtualDeviceConfigSpec getDiskDeviceConfigSpec(ConnectionResources connectionResources,
ManagedObjectReference vmMor,
VmInputs vmInputs) throws Exception {
if (Operation.ADD.toString().equalsIgnoreCase(vmInputs.getOperation())) {
String dataStoreName = getDataStoreWithFreeSpaceNeeded(connectionResources, vmMor,
vmInputs.getLongVmDiskSize());
String volumeName = InputUtils.getDiskFileNameString(dataStoreName, vmInputs.getVirtualMachineName(),
vmInputs.getUpdateValue());
int controllerKey = 0;
int unitNumber = 0;
List getControllerKeysArray = getControllerKey(connectionResources, vmMor);
if (!getControllerKeysArray.isEmpty()) {
controllerKey = getControllerKeysArray.get(0);
unitNumber = getControllerKeysArray.get(1);
}
return new VmUtils().getPopulatedDiskSpec(volumeName, null, VirtualDeviceConfigSpecOperation.ADD,
VirtualDeviceConfigSpecFileOperation.CREATE, controllerKey, unitNumber, SERVER_ASSIGNED,
Operation.ADD.toString(), vmInputs);
} else {
List deviceList = getVirtualDeviceList(connectionResources, vmMor);
return new VmUtils().getPopulatedDiskSpec(Constants.EMPTY, deviceList, VirtualDeviceConfigSpecOperation.REMOVE,
VirtualDeviceConfigSpecFileOperation.DESTROY, DEFAULT_DISK_CONTROLLER_KEY, DEFAULT_DISK_UNIT_NUMBER,
SERVER_ASSIGNED, Operation.REMOVE.toString(), vmInputs);
}
}
VirtualDeviceConfigSpec getCDDeviceConfigSpec(ConnectionResources connectionResources, ManagedObjectReference vmMor,
VmInputs vmInputs) throws RuntimeFaultFaultMsg, InvalidPropertyFaultMsg {
List virtualDevicesList = getVirtualDeviceList(connectionResources, vmMor);
if (Operation.ADD.toString().equalsIgnoreCase(vmInputs.getOperation())) {
Map deviceMap = getVirtualDeviceMap(virtualDevicesList);
for (VirtualDevice virtualDevice : virtualDevicesList) {
if (virtualDevice instanceof VirtualIDEController) {
VirtualIDEController virtualScsiController = (VirtualIDEController) virtualDevice;
List deviceList = virtualScsiController.getDevice();
int[] slots = new int[MAXIMUM_ATAPI_SLOTS];
markOccupiedSlots(deviceMap, deviceList, slots);
int unitNumber = 0;
boolean isAtapiCtrlAvailable = false;
int controllerKey = 0;
for (int counter = 0; counter < slots.length; counter++) {
if (slots[counter] != OCCUPIED) {
controllerKey = virtualScsiController.getKey();
unitNumber = counter;
isAtapiCtrlAvailable = true;
break;
}
}
if (isAtapiCtrlAvailable) {
return new VmUtils().getPopulatedCDSpecs(Constants.EMPTY, null, null,
VirtualDeviceConfigSpecOperation.ADD, controllerKey, unitNumber, SERVER_ASSIGNED,
Operation.ADD.toString(), vmInputs);
}
}
}
throw new RuntimeException(ErrorMessages.ATAPI_CONTROLLER_CAPACITY_MAXED_OUT);
} else {
return new VmUtils().getPopulatedCDSpecs(null, null, virtualDevicesList,
VirtualDeviceConfigSpecOperation.REMOVE, null, null, null, Operation.REMOVE.toString(), vmInputs);
}
}
private void markOccupiedSlots(Map deviceMap, List deviceList, int[] slots) {
for (Integer deviceKey : deviceList) {
if (deviceMap.get(deviceKey).getUnitNumber() != null) {
slots[deviceMap.get(deviceKey).getUnitNumber()] = OCCUPIED;
}
}
}
VirtualDeviceConfigSpec getNICDeviceConfigSpec(ConnectionResources connectionResources, ManagedObjectReference vmMor,
VmInputs vmInputs) throws RuntimeFaultFaultMsg, InvalidPropertyFaultMsg {
if (Operation.ADD.toString().equalsIgnoreCase(vmInputs.getOperation())) {
return new VmUtils().getNicSpecs(vmInputs.getUpdateValue(), null, VirtualDeviceConfigSpecOperation.ADD,
GENERATED, SERVER_ASSIGNED, Operation.ADD.toString(), vmInputs);
} else {
List virtualDevicesList = getVirtualDeviceList(connectionResources, vmMor);
return new VmUtils().getNicSpecs(Constants.EMPTY, virtualDevicesList, VirtualDeviceConfigSpecOperation.REMOVE,
Constants.EMPTY, null, Operation.REMOVE.toString(), vmInputs);
}
}
ResourceAllocationInfo getResourceAllocationInfo(String input) throws Exception {
VmUtils vmUtils = new VmUtils();
SharesInfo sharesInfo = vmUtils.getSharesInfo(input);
ResourceAllocationInfo resourceAllocationInfo = new ResourceAllocationInfo();
resourceAllocationInfo.setShares(sharesInfo);
return resourceAllocationInfo;
}
private VirtualMachineConfigSpec createVmConfigSpec(ConnectionResources connectionResources, VmInputs vmInputs)
throws Exception {
ConfigTarget configTarget = new VmUtils().getHostConfigTarget(connectionResources, connectionResources.getHostMor());
List dataStoresList = configTarget.getDatastore();
String dataStoreName = vmInputs.getDataStore();
ManagedObjectReference dataStoreRef = null;
if (StringUtils.isNotBlank(dataStoreName)) {
dataStoreRef = new VmUtils().getDataStoreRef(dataStoreName, dataStoresList);
} else {
boolean isDsAvailable = false;
for (VirtualMachineDatastoreInfo dataStore : dataStoresList) {
DatastoreSummary dsSummary = dataStore.getDatastore();
if (dsSummary.isAccessible()) {
dataStoreName = dsSummary.getName();
dataStoreRef = dsSummary.getDatastore();
isDsAvailable = true;
break;
}
}
if (!isDsAvailable) {
throw new RuntimeException(ErrorMessages.DATA_STORE_NOT_FOUND_ON_HOST);
}
}
String volumeName = getVolumeName(dataStoreName);
VmUtils vmUtils = new VmUtils();
VirtualDeviceConfigSpec diskSpec = vmUtils.getPopulatedDiskSpec(volumeName, null,
VirtualDeviceConfigSpecOperation.ADD, VirtualDeviceConfigSpecFileOperation.CREATE,
DEFAULT_DISK_CONTROLLER_KEY, DEFAULT_DISK_UNIT_NUMBER, DEFAULT_DISK_KEY, Operation.CREATE.toString(), vmInputs);
VirtualDevice ideController = getFirstFreeIdeController(connectionResources);
VirtualDeviceConfigSpec cdSpec = new VirtualDeviceConfigSpec();
if (ideController != null) {
cdSpec = vmUtils.getPopulatedCDSpecs(volumeName, dataStoreRef, null,
VirtualDeviceConfigSpecOperation.ADD, ideController.getKey(), DEFAULT_CD_ROM_UNIT_NUMBER,
DEFAULT_CD_ROM_KEY, Operation.ADD.toString(), vmInputs);
}
String networkName = getNetworkName(configTarget);
VirtualDeviceConfigSpec nicSpec = new VirtualDeviceConfigSpec();
if (configTarget.getNetwork() != null) {
nicSpec = vmUtils.getNicSpecs(networkName, null, VirtualDeviceConfigSpecOperation.ADD, GENERATED,
DEFAULT_NIC_KEY, Operation.ADD.toString(), vmInputs);
}
VirtualMachineConfigSpec configSpec = getVirtualMachineConfigSpec(dataStoreName);
VirtualDeviceConfigSpec scsiCtrlSpec = getFirstScsiController(DEFAULT_DISK_CONTROLLER_KEY);
VirtualDeviceConfigSpec floppySpec = createFloppyConfigSpecs();
return addDeviceConfigSpecs(configSpec, scsiCtrlSpec, floppySpec, cdSpec, ideController, diskSpec, nicSpec);
}
private VirtualMachineConfigSpec getVirtualMachineConfigSpec(String dataStoreName) {
VirtualMachineFileInfo virtualMachineFileInfo = new VirtualMachineFileInfo();
virtualMachineFileInfo.setVmPathName(getVolumeName(dataStoreName));
VirtualMachineConfigSpec configSpec = new VirtualMachineConfigSpec();
configSpec.setFiles(virtualMachineFileInfo);
return configSpec;
}
private String getVolumeName(String name) {
return StringUtils.isBlank(name) ? DEFAULT_VOLUME_NAME : LEFT_SQUARE_BRACKET + name + Constants.RIGHT_SQUARE_BRACKET;
}
private VirtualDeviceConfigSpec getFirstScsiController(int diskCtrlKey) {
VirtualLsiLogicController scsiCtrl = new VirtualLsiLogicController();
scsiCtrl.setBusNumber(DEFAULT_CONTROLLER_BUS_NUMBER);
scsiCtrl.setKey(diskCtrlKey);
scsiCtrl.setSharedBus(VirtualSCSISharing.NO_SHARING);
return getVirtualDeviceConfigSpec(scsiCtrl);
}
@NotNull
private VirtualDeviceConfigSpec getVirtualDeviceConfigSpec(VirtualDevice virtualDevice) {
VirtualDeviceConfigSpec scsiCtrlSpec = new VirtualDeviceConfigSpec();
scsiCtrlSpec.setOperation(VirtualDeviceConfigSpecOperation.ADD);
scsiCtrlSpec.setDevice(virtualDevice);
return scsiCtrlSpec;
}
private VirtualDevice getFirstFreeIdeController(ConnectionResources connectionResources)
throws RuntimeFaultFaultMsg, InvalidPropertyFaultMsg {
List defaultDevices = getDefaultDevicesList(connectionResources);
for (VirtualDevice device : defaultDevices) {
if (device instanceof VirtualIDEController) {
return device;
}
}
return null;
}
private VirtualDeviceConfigSpec createFloppyConfigSpecs() {
VirtualFloppyDeviceBackingInfo flpBacking = new VirtualFloppyDeviceBackingInfo();
flpBacking.setDeviceName(DEFAULT_FLOPPY_DEVICE_NAME);
VirtualFloppy floppyDisk = new VirtualFloppy();
floppyDisk.setBacking(flpBacking);
floppyDisk.setKey(DEFAULT_FLOPPY_DEVICE_KEY);
return getVirtualDeviceConfigSpec(floppyDisk);
}
private List getDefaultDevicesList(ConnectionResources connectionResources)
throws RuntimeFaultFaultMsg, InvalidPropertyFaultMsg {
ManagedObjectReference environmentBrowserMor = new MorObjectHandler()
.getEnvironmentBrowser(connectionResources, ManagedObjectType.ENVIRONMENT_BROWSER.getValue());
VirtualMachineConfigOption configOptions = connectionResources.getVimPortType()
.queryConfigOption(environmentBrowserMor, null, connectionResources.getHostMor());
if (configOptions == null) {
throw new RuntimeException(ErrorMessages.VIRTUAL_HARDWARE_INFO_NOT_FOUND_IN_COMPUTE_RESOURCE);
}
List listVirtualDevices = configOptions.getDefaultDevice();
if (listVirtualDevices == null) {
throw new RuntimeException(ErrorMessages.DATA_STORE_NOT_FOUND_IN_COMPUTE_RESOURCE);
}
return listVirtualDevices;
}
private String getNetworkName(ConfigTarget configTarget) {
if (configTarget.getNetwork() != null) {
for (VirtualMachineNetworkInfo network : configTarget.getNetwork()) {
NetworkSummary netSummary = network.getNetwork();
if (netSummary.isAccessible()) {
return netSummary.getName();
}
}
}
return null;
}
private VirtualMachineConfigSpec addDeviceConfigSpecs(VirtualMachineConfigSpec configSpec, VirtualDeviceConfigSpec scsiCtrlSpec,
VirtualDeviceConfigSpec floppySpec, VirtualDeviceConfigSpec cdSpec,
VirtualDevice ideController, VirtualDeviceConfigSpec diskSpec,
VirtualDeviceConfigSpec nicSpec) {
List deviceConfigSpec = new ArrayList<>();
deviceConfigSpec.add(scsiCtrlSpec);
deviceConfigSpec.add(floppySpec);
deviceConfigSpec.add(diskSpec);
deviceConfigSpec.add(nicSpec);
if (ideController != null) {
deviceConfigSpec.add(cdSpec);
}
configSpec.getDeviceChange().addAll(deviceConfigSpec);
return configSpec;
}
private String getDataStoreWithFreeSpaceNeeded(ConnectionResources connectionResources, ManagedObjectReference vmMor,
long minFreeSpace) throws InvalidPropertyFaultMsg, RuntimeFaultFaultMsg {
List dataStores = ((ArrayOfManagedObjectReference) connectionResources.getMoRefHandler()
.entityProps(vmMor, new String[]{ManagedObjectType.DATA_STORE.getValue()}).get(ManagedObjectType.DATA_STORE.getValue()))
.getManagedObjectReference();
for (ManagedObjectReference dataStore : dataStores) {
DatastoreSummary datastoreSummary = (DatastoreSummary) connectionResources.getMoRefHandler()
.entityProps(dataStore, new String[]{ManagedObjectType.SUMMARY.getValue()}).get(ManagedObjectType.SUMMARY.getValue());
if (datastoreSummary.getFreeSpace() > minFreeSpace) {
return datastoreSummary.getName();
}
}
throw new RuntimeException("Cannot find any dataStore with: [" + minFreeSpace + "] minimum amount of space available.");
}
private List getControllerKey(ConnectionResources connectionResources, ManagedObjectReference vmMor)
throws InvalidPropertyFaultMsg, RuntimeFaultFaultMsg {
List virtualDevicesList = getVirtualDeviceList(connectionResources, vmMor);
Map deviceMap = getVirtualDeviceMap(virtualDevicesList);
for (VirtualDevice virtualDevice : virtualDevicesList) {
if (virtualDevice instanceof VirtualSCSIController) {
VirtualSCSIController scsiController = (VirtualSCSIController) virtualDevice;
int[] slots = new int[MAXIMUM_SCSI_SLOTS];
slots[RESERVED_SCSI_SLOT] = OCCUPIED;
List deviceKeyList = scsiController.getDevice();
markOccupiedSlots(deviceMap, deviceKeyList, slots);
for (int counter = 0; counter < slots.length; counter++) {
if (slots[counter] != OCCUPIED) {
List controllerKeys = new ArrayList<>();
controllerKeys.add(scsiController.getKey());
controllerKeys.add(counter);
return controllerKeys;
}
}
}
}
throw new RuntimeException(ErrorMessages.SCSI_CONTROLLER_CAPACITY_MAXED_OUT);
}
private List getVirtualDeviceList(ConnectionResources connectionResources, ManagedObjectReference vmMor) throws InvalidPropertyFaultMsg, RuntimeFaultFaultMsg {
return ((ArrayOfVirtualDevice) connectionResources.getMoRefHandler()
.entityProps(vmMor, new String[]{CONFIG_HARDWARE_DEVICE}).get(CONFIG_HARDWARE_DEVICE))
.getVirtualDevice();
}
private Map getVirtualDeviceMap(List virtualDevicesList) {
Map deviceMap = new HashMap<>();
for (VirtualDevice virtualDevice : virtualDevicesList) {
deviceMap.put(virtualDevice.getKey(), virtualDevice);
}
return deviceMap;
}
}