package com.sequenceiq.cloudbreak.cloud.handler; import com.sequenceiq.cloudbreak.cloud.context.CloudContext; import com.sequenceiq.cloudbreak.cloud.event.resource.GetInstancesStateRequest; import com.sequenceiq.cloudbreak.cloud.event.resource.GetInstancesStateResult; import com.sequenceiq.cloudbreak.cloud.model.CloudVmInstanceStatus; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.stereotype.Component; import reactor.bus.Event; import reactor.bus.EventBus; import javax.inject.Inject; import java.util.List; @Component public class InstanceStateHandler implements CloudPlatformEventHandler<GetInstancesStateRequest> { private static final Logger LOGGER = LoggerFactory.getLogger(InstanceStateHandler.class); @Inject private EventBus eventBus; @Inject private InstanceStateQuery instanceStateQuery; @Override public Class<GetInstancesStateRequest> type() { return GetInstancesStateRequest.class; } @Override public void accept(Event<GetInstancesStateRequest> event) { LOGGER.info("Received event: {}", event); GetInstancesStateRequest request = event.getData(); CloudContext cloudContext = request.getCloudContext(); GetInstancesStateResult result; try { List<CloudVmInstanceStatus> instanceStatuses = instanceStateQuery.getCloudVmInstanceStatuses( request.getCloudCredential(), cloudContext, request.getInstances()); result = new GetInstancesStateResult(request, instanceStatuses); } catch (Exception e) { result = new GetInstancesStateResult("Instance state synchronizing failed", e, request); } request.getResult().onNext(result); eventBus.notify(result.selector(), new Event(event.getHeaders(), result)); } }