summaryrefslogtreecommitdiffstats
path: root/dcae-analytics/dcae-analytics-tca-web/src/main/java/org/onap/dcae/analytics/tca/web/integration/TcaPublisherResponseHandler.java
blob: 7cd542cc888882be4ca6e901ddd491ab960c9f51 (plain)
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);
    }

}