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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
/*
* ================================================================================
* Copyright (c) 2018 AT&T Intellectual Property. All rights reserved.
* ================================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* ============LICENSE_END=========================================================
*
*/
package org.onap.dcae.analytics.tca.web.integration;
import static org.onap.dcae.analytics.model.AnalyticsHttpConstants.REQUEST_BEGIN_TS_HEADER_KEY;
import static org.onap.dcae.analytics.model.AnalyticsHttpConstants.REQUEST_END_TS_HEADER_KEY;
import java.util.Date;
import java.util.Map;
import org.onap.dcae.analytics.model.ecomplogger.AnalyticsErrorType;
import org.onap.dcae.analytics.tca.core.util.TcaUtils;
import org.onap.dcae.analytics.tca.web.TcaAppProperties;
import org.onap.dcae.analytics.web.util.AnalyticsHttpUtils;
import org.onap.dcae.utils.eelf.logger.api.info.ResponseLogInfo;
import org.onap.dcae.utils.eelf.logger.api.log.EELFLogFactory;
import org.onap.dcae.utils.eelf.logger.api.log.EELFLogger;
import org.onap.dcae.utils.eelf.logger.model.info.RequestIdLogInfoImpl;
import org.onap.dcae.utils.eelf.logger.model.info.RequestTimingLogInfoImpl;
import org.onap.dcae.utils.eelf.logger.model.info.ResponseLogInfoImpl;
import org.onap.dcae.utils.eelf.logger.model.spec.AuditLogSpecImpl;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.integration.handler.GenericHandler;
import org.springframework.messaging.MessageHeaders;
/**
* TCA Publisher Response Handler is used to do logging of response received from DMaaP MR Publisher. It does not do
* any changes to payload or headers
*
* @author Rajiv Singla
*/
public class TcaPublisherResponseHandler implements GenericHandler<String> {
private static final EELFLogger ECOMP_LOGGER = EELFLogFactory.getLogger(TcaPublisherResponseHandler.class);
private static final Logger logger = LoggerFactory.getLogger(TcaPublisherResponseHandler.class);
private final TcaAppProperties tcaAppProperties;
public TcaPublisherResponseHandler(final TcaAppProperties tcaAppProperties) {
this.tcaAppProperties = tcaAppProperties;
}
@Override
public Object handle(final String payload, final Map<String, Object> headers) {
final MessageHeaders messageHeaders = new MessageHeaders(headers);
final String requestId = AnalyticsHttpUtils.getRequestId(messageHeaders);
final String transactionId = AnalyticsHttpUtils.getTransactionId(messageHeaders);
final Date beginTimestamp = AnalyticsHttpUtils.getTimestampFromHeaders(headers, REQUEST_BEGIN_TS_HEADER_KEY);
final Date endTimestamp = AnalyticsHttpUtils.getTimestampFromHeaders(headers, REQUEST_END_TS_HEADER_KEY);
if (tcaAppProperties.getTca().getEnableEcompLogging()) {
createAuditLog(requestId, transactionId, beginTimestamp, endTimestamp, payload);
} else {
logger.info("Request Id: {}, Transaction Id: {}, Transaction completion Time: {} ms, " +
"DMaaP MR Publisher Response: {}", requestId, transactionId,
endTimestamp.getTime() - beginTimestamp.getTime(), payload);
}
return payload;
}
private static void createAuditLog(final String requestId,
final String transactionId,
final Date requestBeginTimestamp,
final Date requestEndTimestamp,
final String tcaPublisherResponse) {
final RequestIdLogInfoImpl requestIdLogInfo = new RequestIdLogInfoImpl(requestId);
final long elapsedTime = requestEndTimestamp.getTime() - requestBeginTimestamp.getTime();
final RequestTimingLogInfoImpl requestTimingLogInfo = new RequestTimingLogInfoImpl(requestBeginTimestamp,
requestEndTimestamp, elapsedTime);
final ResponseLogInfo responseLogInfo =
new ResponseLogInfoImpl(AnalyticsErrorType.SUCCESSFUL.getErrorCode(),
AnalyticsErrorType.SUCCESSFUL.getErrorDescription());
final AuditLogSpecImpl auditLogSpec = new AuditLogSpecImpl(requestIdLogInfo, TcaUtils.TCA_SERVICE_LOG_INFO,
requestTimingLogInfo, responseLogInfo);
ECOMP_LOGGER.auditLog().info("Request Id: {}, Transaction Id: {}, " +
"Transaction completion Time: {} ms, DMaaP MR Publisher Response: {}",
auditLogSpec, requestId, transactionId, Long.toString(elapsedTime), tcaPublisherResponse);
}
}
|