-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLoggingRequestInterceptor.java
71 lines (62 loc) · 3.61 KB
/
LoggingRequestInterceptor.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package com.att.eg.catalog.cms.ingest.gitignore;
import com.att.ajsc.common.discovery.datastore.rest.Status;
import com.att.ajsc.common.discovery.datastore.utils.ObjectMapperUtils;
import com.att.eg.monitoring.yawl.YawlLogger;
import com.fasterxml.jackson.core.util.DefaultIndenter;
import com.fasterxml.jackson.core.util.DefaultPrettyPrinter;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectReader;
import com.fasterxml.jackson.databind.ObjectWriter;
import org.springframework.http.HttpRequest;
import org.springframework.http.client.ClientHttpRequestExecution;
import org.springframework.http.client.ClientHttpRequestInterceptor;
import org.springframework.http.client.ClientHttpResponse;
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
public class LoggingRequestInterceptor implements ClientHttpRequestInterceptor {
private static final YawlLogger log = new YawlLogger(LoggingRequestInterceptor.class);
@Override
public ClientHttpResponse intercept(final HttpRequest request, final byte[] body,
final ClientHttpRequestExecution execution) throws IOException {
traceRequest(request, body);
ClientHttpResponse response = execution.execute(request, body);
traceResponse(response);
return response;
}
private void traceRequest(HttpRequest request, byte[] body) throws IOException {
log.debug(Status.OK, "", "===========================request begin================================================");
log.debug(Status.OK, "URI : {}", request.getURI());
log.debug(Status.OK, "Method : {}", request.getMethod());
ObjectReader objectReader = ObjectMapperUtils.JACKSON.reader();
DefaultPrettyPrinter prettyPrinter = new DefaultPrettyPrinter();
prettyPrinter.indentArraysWith( DefaultIndenter.SYSTEM_LINEFEED_INSTANCE );
ObjectWriter objectWriter = ObjectMapperUtils.JACKSON.writer(prettyPrinter);
JsonNode jsonNode = objectReader.readTree(new String(body, "UTF-8"));
System.out.println();
System.out.println();
System.out.println();
log.debug(Status.OK, "Headers : {}", objectWriter.writeValueAsString(request.getHeaders()));
log.debug(Status.OK, "Request body: {}", objectWriter.writeValueAsString(jsonNode));
System.out.println();
System.out.println();
System.out.println();
log.debug(Status.OK, "", "==========================request end================================================");
}
private void traceResponse(ClientHttpResponse response) throws IOException {
StringBuilder inputStringBuilder = new StringBuilder();
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(response.getBody(), "UTF-8"));
String line = bufferedReader.readLine();
while (line != null) {
inputStringBuilder.append(line);
inputStringBuilder.append(System.lineSeparator());
line = bufferedReader.readLine();
}
log.debug(Status.OK, "", "============================response begin==========================================");
log.debug(Status.OK, "Status code : {}", response.getStatusCode());
log.debug(Status.OK, "Status text : {}", response.getStatusText());
log.debug(Status.OK, "Headers : {}", response.getHeaders());
log.debug(Status.OK, "Response body: {}", inputStringBuilder.toString());
log.debug(Status.OK, "", "=======================response end=================================================");
}
}