use of com.sequenceiq.cloudbreak.structuredevent.event.rest.RestRequestDetails in project cloudbreak by hortonworks.
the class LegacyRestCommonServiceTest method testWhenNameAndResourceCrnNotExists.
@Test
public void testWhenNameAndResourceCrnNotExists() {
StructuredRestCallEvent event = new StructuredRestCallEvent();
OperationDetails operation = new OperationDetails();
RestCallDetails restCallDetails = new RestCallDetails();
RestRequestDetails request = new RestRequestDetails();
request.setMethod("POST");
request.setRequestUri("uri");
RestResponseDetails response = new RestResponseDetails();
restCallDetails.setRestRequest(request);
restCallDetails.setRestResponse(response);
event.setRestCall(restCallDetails);
event.setOperation(operation);
UnsupportedOperationException exception = assertThrows(UnsupportedOperationException.class, () -> legacyRestCommonService.addClusterCrnAndNameIfPresent(event));
assertEquals(exception.getMessage(), "Cannot determine the resource crn or name, so we does not support for auditing for method: " + "POST, uri: uri, body: null");
}
use of com.sequenceiq.cloudbreak.structuredevent.event.rest.RestRequestDetails in project cloudbreak by hortonworks.
the class LegacyRestCommonServiceTest method testWhenNameAndResourceCrnComeFromTheRequestBodyButExistInResponse.
@Test
public void testWhenNameAndResourceCrnComeFromTheRequestBodyButExistInResponse() {
StructuredRestCallEvent event = new StructuredRestCallEvent();
OperationDetails operation = new OperationDetails();
RestCallDetails restCallDetails = new RestCallDetails();
RestRequestDetails request = new RestRequestDetails();
request.setBody(new Json(Map.of("name", "name2", "resourceCrn", "crn2")).getValue());
RestResponseDetails response = new RestResponseDetails();
response.setBody(new Json(Map.of("name", "name3", "resourceCrn", "crn3")).getValue());
restCallDetails.setRestRequest(request);
restCallDetails.setRestResponse(response);
event.setRestCall(restCallDetails);
event.setOperation(operation);
Map<String, Object> expected = new HashMap<>();
expected.put(CLUSTER_NAME, "name2");
expected.put(CLUSTER_CRN, "crn2");
Map<String, Object> actual = legacyRestCommonService.addClusterCrnAndNameIfPresent(event);
assertEquals(expected, actual);
}
use of com.sequenceiq.cloudbreak.structuredevent.event.rest.RestRequestDetails in project cloudbreak by hortonworks.
the class LegacyRestCommonServiceTest method testWhenNamesAndCrnAreListAndMethodDelete.
@Test
public void testWhenNamesAndCrnAreListAndMethodDelete() {
StructuredRestCallEvent event = new StructuredRestCallEvent();
OperationDetails operation = new OperationDetails();
RestCallDetails restCallDetails = new RestCallDetails();
RestRequestDetails request = new RestRequestDetails();
request.setMethod("DELETE");
request.setBody(new Json(Map.of("names", List.of("names1", "names2"), "crns", List.of("crns1", "crns2"))).getValue());
RestResponseDetails response = new RestResponseDetails();
restCallDetails.setRestRequest(request);
restCallDetails.setRestResponse(response);
event.setRestCall(restCallDetails);
event.setOperation(operation);
Map<String, Object> expected = new HashMap<>();
expected.put(CLUSTER_NAME, "names1,names2");
expected.put(CLUSTER_CRN, "crns1,crns2");
Map<String, Object> actual = legacyRestCommonService.addClusterCrnAndNameIfPresent(event);
assertEquals(expected, actual);
}
use of com.sequenceiq.cloudbreak.structuredevent.event.rest.RestRequestDetails in project cloudbreak by hortonworks.
the class LegacyStructuredEventFilter method filter.
@Override
public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext) {
if (BooleanUtils.isTrue((Boolean) requestContext.getProperty(LOGGING_ENABLED_PROPERTY))) {
RestResponseDetails restResponse = createResponseDetails(responseContext);
if (responseContext.hasEntity()) {
OutputStream stream = new LoggingStream(responseContext.getEntityStream());
responseContext.setEntityStream(stream);
requestContext.setProperty(LOGGINGSTREAM_PROPERTY, stream);
requestContext.setProperty(RESPONSE_DETAILS, restResponse);
} else {
Long requestTime = (Long) requestContext.getProperty(REQUEST_TIME);
RestRequestDetails restRequest = (RestRequestDetails) requestContext.getProperty(REQUEST_DETAILS);
Map<String, String> restParams = (Map<String, String>) requestContext.getProperty(REST_PARAMS);
sendStructuredEvent(restRequest, restResponse, restParams, requestTime, "");
}
}
}
use of com.sequenceiq.cloudbreak.structuredevent.event.rest.RestRequestDetails in project cloudbreak by hortonworks.
the class StructuredEventFilter method filter.
@Override
public void filter(ContainerRequestContext requestContext, ContainerResponseContext responseContext) {
if (BooleanUtils.isTrue((Boolean) requestContext.getProperty(LOGGING_ENABLED_PROPERTY))) {
RestResponseDetails restResponse = createResponseDetails(responseContext);
if (responseContext.hasEntity()) {
OutputStream stream = new LoggingStream(responseContext.getEntityStream());
responseContext.setEntityStream(stream);
requestContext.setProperty(LOGGINGSTREAM_PROPERTY, stream);
requestContext.setProperty(RESPONSE_DETAILS, restResponse);
} else {
Long requestTime = (Long) requestContext.getProperty(REQUEST_TIME);
RestRequestDetails restRequest = (RestRequestDetails) requestContext.getProperty(REQUEST_DETAILS);
Map<String, String> restParams = (Map<String, String>) requestContext.getProperty(REST_PARAMS);
sendStructuredEvent(restRequest, restResponse, restParams, requestTime, "");
}
}
}
Aggregations