// Licensed to the Apache Software Foundation (ASF) under one // or more contributor license agreements. See the NOTICE file // distributed with this work for additional information // regarding copyright ownership. The ASF licenses this file // to you under the Apache 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.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 com.cloud.server; import java.net.URISyntaxException; import java.util.ArrayList; import java.util.List; import java.util.Map; import java.util.Set; import com.cloud.alert.Alert; import org.apache.cloudstack.api.ServerApiException; import org.apache.cloudstack.api.command.admin.cluster.ListClustersCmd; import org.apache.cloudstack.api.command.admin.host.ListHostsCmd; import org.apache.cloudstack.api.command.admin.host.UpdateHostPasswordCmd; import org.apache.cloudstack.api.command.admin.pod.ListPodsByCmd; import org.apache.cloudstack.api.command.admin.resource.ListAlertsCmd; import org.apache.cloudstack.api.command.admin.resource.ListCapacityCmd; import org.apache.cloudstack.api.command.admin.domain.UpdateDomainCmd; import org.apache.cloudstack.api.command.admin.storage.ListStoragePoolsCmd; import org.apache.cloudstack.api.command.admin.systemvm.*; import org.apache.cloudstack.api.command.admin.vlan.ListVlanIpRangesCmd; import org.apache.cloudstack.api.command.user.address.ListPublicIpAddressesCmd; import org.apache.cloudstack.api.command.user.config.ListCapabilitiesCmd; import org.apache.cloudstack.api.command.user.guest.ListGuestOsCmd; import org.apache.cloudstack.api.command.user.offering.ListDiskOfferingsCmd; import org.apache.cloudstack.api.command.user.offering.ListServiceOfferingsCmd; import org.apache.cloudstack.api.command.user.ssh.DeleteSSHKeyPairCmd; import org.apache.cloudstack.api.command.user.ssh.CreateSSHKeyPairCmd; import org.apache.cloudstack.api.command.user.template.ListTemplatesCmd; import org.apache.cloudstack.api.command.user.vm.GetVMPasswordCmd; import org.apache.cloudstack.api.command.user.volume.ExtractVolumeCmd; import org.apache.cloudstack.api.command.user.template.UpdateTemplateCmd; import org.apache.cloudstack.api.command.admin.config.ListCfgsByCmd; import org.apache.cloudstack.api.command.user.guest.ListGuestOsCategoriesCmd; import org.apache.cloudstack.api.command.user.iso.ListIsosCmd; import org.apache.cloudstack.api.command.user.ssh.ListSSHKeyPairsCmd; import org.apache.cloudstack.api.command.admin.systemvm.ListSystemVMsCmd; import org.apache.cloudstack.api.command.user.zone.ListZonesByCmd; import org.apache.cloudstack.api.command.admin.systemvm.RebootSystemVmCmd; import org.apache.cloudstack.api.command.user.ssh.RegisterSSHKeyPairCmd; import org.apache.cloudstack.api.command.admin.systemvm.StopSystemVmCmd; import org.apache.cloudstack.api.command.user.iso.UpdateIsoCmd; import org.apache.cloudstack.api.command.user.vmgroup.UpdateVMGroupCmd; import org.apache.cloudstack.api.command.admin.systemvm.UpgradeSystemVMCmd; import org.apache.cloudstack.api.command.admin.resource.UploadCustomCertificateCmd; import com.cloud.capacity.Capacity; import com.cloud.configuration.Configuration; import com.cloud.dc.DataCenter; import com.cloud.dc.Pod; import com.cloud.dc.Vlan; import com.cloud.domain.Domain; import com.cloud.exception.ConcurrentOperationException; import com.cloud.exception.InternalErrorException; import com.cloud.exception.PermissionDeniedException; import com.cloud.exception.ResourceUnavailableException; import com.cloud.host.Host; import com.cloud.hypervisor.Hypervisor.HypervisorType; import com.cloud.hypervisor.HypervisorCapabilities; import com.cloud.network.IpAddress; import com.cloud.offering.DiskOffering; import com.cloud.offering.ServiceOffering; import com.cloud.org.Cluster; import com.cloud.storage.GuestOS; import com.cloud.storage.GuestOsCategory; import com.cloud.storage.StoragePool; import com.cloud.template.VirtualMachineTemplate; import com.cloud.user.SSHKeyPair; import com.cloud.utils.Pair; import com.cloud.vm.InstanceGroup; import com.cloud.vm.VirtualMachine; import com.cloud.vm.VirtualMachine.Type; /** * Hopefully this is temporary. * */ public interface ManagementService { static final String Name = "management-server"; /** * returns the a map of the names/values in the configuraton table * * @return map of configuration name/values */ Pair, Integer> searchForConfigurations(ListCfgsByCmd c); /** * Searches for Clusters by the specified search criteria * * @param c * @return */ Pair, Integer> searchForClusters(ListClustersCmd c); /** * Searches for Clusters by the specified zone Id. * @param zoneId * @return */ List searchForClusters(long zoneId, Long startIndex, Long pageSizeVal, String hypervisorType); /** * Searches for Pods by the specified search criteria Can search by: pod name and/or zone name * * @param cmd * @return List of Pods */ Pair, Integer> searchForPods(ListPodsByCmd cmd); /** * Searches for servers by the specified search criteria Can search by: "name", "type", "state", "dataCenterId", * "podId" * * @param cmd * @return List of Hosts */ Pair, Integer> searchForServers(ListHostsCmd cmd); /** * Creates a new template * * @param cmd * @return updated template */ VirtualMachineTemplate updateTemplate(UpdateIsoCmd cmd); VirtualMachineTemplate updateTemplate(UpdateTemplateCmd cmd); /** * Obtains a list of IP Addresses by the specified search criteria. Can search by: "userId", "dataCenterId", * "address" * * @param cmd * the command that wraps the search criteria * @return List of IPAddresses */ Pair, Integer> searchForIPAddresses(ListPublicIpAddressesCmd cmd); /** * Obtains a list of all guest OS. * * @return list of GuestOS */ Pair, Integer> listGuestOSByCriteria(ListGuestOsCmd cmd); /** * Obtains a list of all guest OS categories. * * @return list of GuestOSCategories */ Pair, Integer> listGuestOSCategoriesByCriteria(ListGuestOsCategoriesCmd cmd); VirtualMachine stopSystemVM(StopSystemVmCmd cmd) throws ResourceUnavailableException, ConcurrentOperationException; VirtualMachine startSystemVM(long vmId); VirtualMachine rebootSystemVM(RebootSystemVmCmd cmd); VirtualMachine destroySystemVM(DestroySystemVmCmd cmd); VirtualMachine upgradeSystemVM(UpgradeSystemVMCmd cmd); /** * update an existing domain * * @param cmd * - the command containing domainId and new domainName * @return Domain object if the command succeeded */ Domain updateDomain(UpdateDomainCmd cmd); /** * Searches for alerts * * @param c * @return List of Alerts */ Pair, Integer> searchForAlerts(ListAlertsCmd cmd); /** * list all the capacity rows in capacity operations table * * @param cmd * @return List of capacities */ List listCapacities(ListCapacityCmd cmd); /** * List ISOs that match the specified criteria. * * @param cmd * The command that wraps the (optional) templateId, name, keyword, templateFilter, bootable, account, * and zoneId * parameters. * @return list of ISOs */ Set> listIsos(ListIsosCmd cmd); /** * List templates that match the specified criteria. * * @param cmd * The command that wraps the (optional) templateId, name, keyword, templateFilter, bootable, account, * and zoneId * parameters. * @return list of ISOs */ Set> listTemplates(ListTemplatesCmd cmd); /** * List system VMs by the given search criteria * * @param cmd * the command that wraps the search criteria (host, name, state, type, zone, pod, and/or id) * @return the list of system vms that match the given criteria */ Pair, Integer> searchForSystemVm(ListSystemVMsCmd cmd); /** * Returns back a SHA1 signed response * * @param userId * -- id for the user * @return -- ArrayList of */ ArrayList getCloudIdentifierResponse(long userId); boolean updateHostPassword(UpdateHostPasswordCmd cmd); InstanceGroup updateVmGroup(UpdateVMGroupCmd cmd); Map listCapabilities(ListCapabilitiesCmd cmd); /** * Extracts the volume to a particular location. * * @param cmd * the command specifying url (where the volume needs to be extracted to), zoneId (zone where the volume * exists), * id (the id of the volume) * @throws URISyntaxException * @throws InternalErrorException * @throws PermissionDeniedException * */ Long extractVolume(ExtractVolumeCmd cmd) throws URISyntaxException; /** * return an array of available hypervisors * * @param zoneId * TODO * * @return an array of available hypervisors in the cloud */ List getHypervisors(Long zoneId); /** * This method uploads a custom cert to the db, and patches every cpvm with it on the current ms * * @param cmd * -- upload certificate cmd * @return -- returns a string on success * @throws ServerApiException * -- even if one of the console proxy patching fails, we throw back this exception */ String uploadCertificate(UploadCustomCertificateCmd cmd); String getVersion(); /** * Searches for vlan by the specified search criteria Can search by: "id", "vlan", "name", "zoneID" * * @param cmd * @return List of Vlans */ Pair, Integer> searchForVlans(ListVlanIpRangesCmd cmd); /** * Generates a random password that will be used (initially) by newly created and started virtual machines * * @return a random password */ String generateRandomPassword(); public Long saveStartedEvent(Long userId, Long accountId, String type, String description, long startEventId); public Long saveCompletedEvent(Long userId, Long accountId, String level, String type, String description, long startEventId); /** * Search registered key pairs for the logged in user. * * @param cmd * The api command class. * @return The list of key pairs found. */ Pair, Integer> listSSHKeyPairs(ListSSHKeyPairsCmd cmd); /** * Registers a key pair for a given public key. * * @param cmd * The api command class. * @return A VO with the key pair name and a finger print for the public key. */ SSHKeyPair registerSSHKeyPair(RegisterSSHKeyPairCmd cmd); /** * Creates a new * * @param cmd * The api command class. * @return A VO containing the key pair name, finger print for the public key and the private key material of the * key pair. */ SSHKeyPair createSSHKeyPair(CreateSSHKeyPairCmd cmd); /** * Deletes a key pair by name. * * @param cmd * The api command class. * @return True on success. False otherwise. */ boolean deleteSSHKeyPair(DeleteSSHKeyPairCmd cmd); /** * Finds and returns an encrypted password for a VM. * * @param cmd * The api command class. * @return The encrypted password. */ String getVMPassword(GetVMPasswordCmd cmd); Type findSystemVMTypeById(long instanceId); /** * List hosts for migrating the given VM. The API returns list of all hosts in the VM's cluster minus the current * host and * also a list of hosts that seem to have enough CPU and RAM capacity to host this VM. * * @param Long * vmId * Id of The VM to migrate * @return Pair, List> List of all Hosts in VM's cluster and list of Hosts with * enough capacity */ Pair, Integer>, List> listHostsForMigrationOfVM(Long vmId, Long startIndex, Long pageSize); String[] listEventTypes(); Pair, Integer> listHypervisorCapabilities(Long id, HypervisorType hypervisorType, String keyword, Long startIndex, Long pageSizeVal); HypervisorCapabilities updateHypervisorCapabilities(Long id, Long maxGuestsLimit, Boolean securityGroupEnabled); /** * list all the top consumed resources across different capacity types * * @param cmd * @return List of capacities */ List listTopConsumedResources(ListCapacityCmd cmd); }