summaryrefslogtreecommitdiffstats
path: root/dcae-analytics/dcae-analytics-tca-core/src/main/java/org/onap/dcae/analytics/tca/core/util/LogSpec.java
blob: 002cf07c27e93f930c48dc06a733413917443ccc (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
102
103
/*
 * ================================================================================
 * Copyright (c) 2018 China Mobile. 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.core.util;

import java.util.Date;

import org.onap.dcae.analytics.model.TcaModelConstants;
import org.onap.dcae.analytics.model.ecomplogger.AnalyticsErrorType;
import org.onap.dcae.utils.eelf.logger.api.info.ErrorLogInfo;
import org.onap.dcae.utils.eelf.logger.api.info.ResponseLogInfo;
import org.onap.dcae.utils.eelf.logger.api.info.TargetServiceLogInfo;
import org.onap.dcae.utils.eelf.logger.api.spec.AuditLogSpec;
import org.onap.dcae.utils.eelf.logger.api.spec.DebugLogSpec;
import org.onap.dcae.utils.eelf.logger.api.spec.ErrorLogSpec;
import org.onap.dcae.utils.eelf.logger.model.info.ErrorLogInfoImpl;
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.info.TargetServiceLogInfoImpl;
import org.onap.dcae.utils.eelf.logger.model.spec.AuditLogSpecImpl;
import org.onap.dcae.utils.eelf.logger.model.spec.DebugLogSpecImpl;
import org.onap.dcae.utils.eelf.logger.model.spec.ErrorLogSpecImpl;

/**
 * @author Kai Lu
 */
public final class LogSpec {

    private LogSpec( ) {
        // private constructor
    }

    /**
     * create ErrorLogSpec
     *
     * @param requestId requestId
     *
     * @return ErrorLogSpecImpl object
     *
     */
    public static ErrorLogSpec createErrorLogSpec(final String requestId) {
        final RequestIdLogInfoImpl requestIdLogInfo = new RequestIdLogInfoImpl(requestId);
        final TargetServiceLogInfo targetServiceLogInfo = new TargetServiceLogInfoImpl(
                "DCAE-TCA", TcaModelConstants.TCA_SERVICE_NAME, "");
        final ErrorLogInfo errorLogInfo =
                new ErrorLogInfoImpl(AnalyticsErrorType.SCHEMA_ERROR.getErrorCode(),
                        AnalyticsErrorType.SCHEMA_ERROR.getErrorDescription());
        return new ErrorLogSpecImpl(requestIdLogInfo,
                TcaUtils.TCA_SERVICE_LOG_INFO, targetServiceLogInfo, errorLogInfo);
    }

    /**
     * create DebugLogSpec
     *
     * @param requestId requestId
     *
     * @return DebugLogSpecImpl object
     *
     */
    public static DebugLogSpec createDebugLogSpec(final String requestId) {
        final RequestIdLogInfoImpl requestIdLogInfo = new RequestIdLogInfoImpl(requestId);
        return new DebugLogSpecImpl(requestIdLogInfo);
    }

    /**
     * create AuditLogSpec
     *
     * @param requestId requestId
     * @param requestBeginTimestamp requestBeginTimestamp
     *
     * @return AuditLogSpec object
     *
     */
    public static AuditLogSpec createAuditLogSpec(final String requestId,
                                                  final Date requestBeginTimestamp) {
        final RequestIdLogInfoImpl requestIdLogInfo = new RequestIdLogInfoImpl(requestId);
        final Date endTimestamp = new Date();
        final RequestTimingLogInfoImpl requestTimingLogInfo = new RequestTimingLogInfoImpl(requestBeginTimestamp,
                endTimestamp, endTimestamp.getTime() - requestBeginTimestamp.getTime());
        final ResponseLogInfo responseLogInfo =
                new ResponseLogInfoImpl(AnalyticsErrorType.SUCCESSFUL.getErrorCode(),
                        AnalyticsErrorType.SUCCESSFUL.getErrorDescription());
        return new AuditLogSpecImpl(requestIdLogInfo, TcaUtils.TCA_SERVICE_LOG_INFO,
                requestTimingLogInfo, responseLogInfo);
    }

}