use of com.sequenceiq.cloudbreak.core.flow2.cmdiagnostics.event.CmDiagnosticsCollectionFailureEvent in project cloudbreak by hortonworks.
the class CmDiagnosticsCleanupHandler method accept.
@Override
public void accept(Event<CmDiagnosticsCollectionEvent> event) {
CmDiagnosticsCollectionEvent data = event.getData();
Long resourceId = data.getResourceId();
String resourceCrn = data.getResourceCrn();
CmDiagnosticsParameters parameters = data.getParameters();
Map<String, Object> parameterMap = parameters.toMap();
try {
LOGGER.debug("CM based diagnostics cleanup started. resourceCrn: '{}', parameters: '{}'", resourceCrn, parameterMap);
if (DiagnosticsDestination.SUPPORT.equals(parameters.getDestination())) {
LOGGER.debug("CM based diagnostics uses SUPPORT destination, no support specific cleanup step yet.");
} else {
cmDiagnosticsFlowService.cleanup(resourceId, parameterMap, new HashSet<>());
}
CmDiagnosticsCollectionEvent diagnosticsCollectionEvent = CmDiagnosticsCollectionEvent.builder().withResourceCrn(resourceCrn).withResourceId(resourceId).withSelector(FINISH_CM_DIAGNOSTICS_COLLECTION_EVENT.selector()).withParameters(parameters).build();
eventSender().sendEvent(diagnosticsCollectionEvent, event.getHeaders());
} catch (Exception e) {
LOGGER.debug("CM based diagnostics cleanup failed. resourceCrn: '{}', parameters: '{}'.", resourceCrn, parameterMap, e);
CmDiagnosticsCollectionFailureEvent failureEvent = new CmDiagnosticsCollectionFailureEvent(resourceId, e, resourceCrn, parameters);
eventBus.notify(failureEvent.selector(), new Event<>(event.getHeaders(), failureEvent));
}
}
use of com.sequenceiq.cloudbreak.core.flow2.cmdiagnostics.event.CmDiagnosticsCollectionFailureEvent in project cloudbreak by hortonworks.
the class CmDiagnosticsInitHandler method accept.
@Override
public void accept(Event<CmDiagnosticsCollectionEvent> event) {
CmDiagnosticsCollectionEvent data = event.getData();
Long resourceId = data.getResourceId();
String resourceCrn = data.getResourceCrn();
CmDiagnosticsParameters parameters = data.getParameters();
Map<String, Object> parameterMap = parameters.toMap();
try {
LOGGER.debug("CM based diagnostics collection initialization started. resourceCrn: '{}', parameters: '{}'", resourceCrn, parameterMap);
if (DiagnosticsDestination.SUPPORT.equals(parameters.getDestination())) {
LOGGER.debug("CM based diagnostics uses SUPPORT destination, no support specific init step yet.");
} else {
cmDiagnosticsFlowService.init(resourceId, parameterMap, new HashSet<>());
}
CmDiagnosticsCollectionEvent diagnosticsCollectionEvent = CmDiagnosticsCollectionEvent.builder().withResourceCrn(resourceCrn).withResourceId(resourceId).withSelector(START_CM_DIAGNOSTICS_COLLECTION_EVENT.selector()).withParameters(parameters).build();
eventSender().sendEvent(diagnosticsCollectionEvent, event.getHeaders());
} catch (Exception e) {
LOGGER.debug("CM based diagnostics collection initialization failed. resourceCrn: '{}', parameters: '{}'.", resourceCrn, parameterMap, e);
CmDiagnosticsCollectionFailureEvent failureEvent = new CmDiagnosticsCollectionFailureEvent(resourceId, e, resourceCrn, parameters);
eventBus.notify(failureEvent.selector(), new Event<>(event.getHeaders(), failureEvent));
}
}
use of com.sequenceiq.cloudbreak.core.flow2.cmdiagnostics.event.CmDiagnosticsCollectionFailureEvent in project cloudbreak by hortonworks.
the class CmDiagnosticsCollectionActions method failedAction.
@Bean(name = "CM_DIAGNOSTICS_COLLECTION_FAILED_STATE")
public Action<?, ?> failedAction() {
return new CmDiagnosticsCollectionActions.AbstractCmDiagnosticsCollectionActions<>(CmDiagnosticsCollectionFailureEvent.class) {
@Override
protected void doExecute(CommonContext context, CmDiagnosticsCollectionFailureEvent payload, Map<Object, Object> variables) {
Long resourceId = payload.getResourceId();
String resourceCrn = payload.getResourceCrn();
LOGGER.debug("Flow entered into CM_DIAGNOSTICS_COLLECTION_FAILED_STATE. resourceCrn: '{}'", resourceCrn);
cloudbreakEventService.fireCloudbreakEvent(resourceId, UPDATE_FAILED.name(), ResourceEvent.STACK_CM_DIAGNOSTICS_COLLECTION_FAILED, List.of(payload.getException().getMessage()));
InMemoryStateStore.deleteStack(resourceId);
CmDiagnosticsCollectionEvent event = CmDiagnosticsCollectionEvent.builder().withResourceId(resourceId).withResourceCrn(payload.getResourceCrn()).withSelector(CmDiagnosticsCollectionStateSelectors.HANDLED_FAILED_CM_DIAGNOSTICS_COLLECTION_EVENT.selector()).withParameters(payload.getParameters()).build();
sendEvent(context, event);
}
};
}
use of com.sequenceiq.cloudbreak.core.flow2.cmdiagnostics.event.CmDiagnosticsCollectionFailureEvent in project cloudbreak by hortonworks.
the class CmDiagnosticsCollectionHandler method accept.
@Override
public void accept(Event<CmDiagnosticsCollectionEvent> event) {
CmDiagnosticsCollectionEvent data = event.getData();
Long resourceId = data.getResourceId();
String resourceCrn = data.getResourceCrn();
CmDiagnosticsParameters parameters = data.getParameters();
Map<String, Object> parameterMap = parameters.toMap();
try {
LOGGER.debug("CM based diagnostics collection started. resourceCrn: '{}', parameters: '{}'", resourceCrn, parameterMap);
clusterDiagnosticsService.collectDiagnostics(resourceId, parameters);
CmDiagnosticsCollectionEvent diagnosticsCollectionEvent = CmDiagnosticsCollectionEvent.builder().withResourceCrn(resourceCrn).withResourceId(resourceId).withSelector(START_CM_DIAGNOSTICS_UPLOAD_EVENT.selector()).withParameters(parameters).build();
eventSender().sendEvent(diagnosticsCollectionEvent, event.getHeaders());
} catch (Exception e) {
LOGGER.debug("CM based diagnostics collection failed. resourceCrn: '{}', parameters: '{}'.", resourceCrn, parameterMap, e);
CmDiagnosticsCollectionFailureEvent failureEvent = new CmDiagnosticsCollectionFailureEvent(resourceId, e, resourceCrn, parameters);
eventBus.notify(failureEvent.selector(), new Event<>(event.getHeaders(), failureEvent));
}
}
use of com.sequenceiq.cloudbreak.core.flow2.cmdiagnostics.event.CmDiagnosticsCollectionFailureEvent in project cloudbreak by hortonworks.
the class CmDiagnosticsUploadHandler method accept.
@Override
public void accept(Event<CmDiagnosticsCollectionEvent> event) {
CmDiagnosticsCollectionEvent data = event.getData();
Long resourceId = data.getResourceId();
String resourceCrn = data.getResourceCrn();
CmDiagnosticsParameters parameters = data.getParameters();
Map<String, Object> parameterMap = parameters.toMap();
try {
LOGGER.debug("CM based diagnostics upload started. resourceCrn: '{}', parameters: '{}'", resourceCrn, parameterMap);
if (DiagnosticsDestination.SUPPORT.equals(parameters.getDestination())) {
LOGGER.debug("CM based diagnostics uses SUPPORT destination, no support specific upload step yet.");
} else {
cmDiagnosticsFlowService.upload(resourceId, parameterMap, new HashSet<>());
}
CmDiagnosticsCollectionEvent diagnosticsCollectionEvent = CmDiagnosticsCollectionEvent.builder().withResourceCrn(resourceCrn).withResourceId(resourceId).withSelector(START_CM_DIAGNOSTICS_CLEANUP_EVENT.selector()).withParameters(parameters).build();
eventSender().sendEvent(diagnosticsCollectionEvent, event.getHeaders());
} catch (Exception e) {
LOGGER.debug("CM based diagnostics upload failed. resourceCrn: '{}', parameters: '{}'.", resourceCrn, parameterMap, e);
CmDiagnosticsCollectionFailureEvent failureEvent = new CmDiagnosticsCollectionFailureEvent(resourceId, e, resourceCrn, parameters);
eventBus.notify(failureEvent.selector(), new Event<>(event.getHeaders(), failureEvent));
}
}
Aggregations