package org.zstack.compute.vm; import org.springframework.beans.factory.annotation.Autowire; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Configurable; import org.zstack.core.cloudbus.CloudBus; import org.zstack.core.cloudbus.CloudBusCallBack; import org.zstack.core.db.DatabaseFacade; import org.zstack.core.errorcode.ErrorFacade; import org.zstack.header.core.workflow.FlowTrigger; import org.zstack.header.core.workflow.NoRollbackFlow; import org.zstack.header.host.HostConstant; import org.zstack.header.host.HostErrors; import org.zstack.header.message.MessageReply; import org.zstack.header.vm.APIStopVmInstanceMsg; import org.zstack.header.vm.StopVmOnHypervisorMsg; import org.zstack.header.vm.VmInstanceConstant; import org.zstack.header.vm.VmInstanceSpec; import java.util.Map; @Configurable(preConstruction = true, autowire = Autowire.BY_TYPE) public class VmStopOnHypervisorFlow extends NoRollbackFlow { @Autowired protected DatabaseFacade dbf; @Autowired protected CloudBus bus; @Autowired protected ErrorFacade errf; @Override public void run(final FlowTrigger chain, Map data) { final VmInstanceSpec spec = (VmInstanceSpec) data.get(VmInstanceConstant.Params.VmInstanceSpec.toString()); StopVmOnHypervisorMsg msg = new StopVmOnHypervisorMsg(); msg.setVmInventory(spec.getVmInventory()); if (spec.getMessage() instanceof APIStopVmInstanceMsg) { msg.setType(((APIStopVmInstanceMsg)spec.getMessage()).getType()); } bus.makeTargetServiceIdByResourceUuid(msg, HostConstant.SERVICE_ID, spec.getVmInventory().getHostUuid()); bus.send(msg, new CloudBusCallBack(chain) { @Override public void run(MessageReply reply) { if (reply.isSuccess()) { chain.next(); } else { if (spec.isGcOnStopFailure() && reply.getError().isError(HostErrors.OPERATION_FAILURE_GC_ELIGIBLE)) { StopVmGC gc = new StopVmGC(); gc.inventory = spec.getVmInventory(); gc.hostUuid = spec.getVmInventory().getHostUuid(); gc.NAME = String.format("gc-stop-vm-%s-%s-on-host-%s", gc.inventory.getUuid(), gc.inventory.getName(), gc.hostUuid); gc.submit(); chain.next(); } else { chain.fail(reply.getError()); } } } }); } }