summaryrefslogtreecommitdiffstats
path: root/dcaedt_be/src/main/java/org/onap/sdc/dcae/errormng/ErrorInfo.java
blob: 3ec3cefc5987ef8762dc042a218fea9a6084561f (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
/*-
 * ============LICENSE_START=======================================================
 * SDC
 * ================================================================================
 * Copyright (C) 2017 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.sdc.dcae.errormng;

import org.onap.sdc.common.onaplog.OnapLoggerDebug;
import org.onap.sdc.common.onaplog.OnapLoggerError;
import org.onap.sdc.common.onaplog.Enums.LogLevel;

public class ErrorInfo {

	private Integer code;
	private String message;
	private String messageId;
	private ErrorInfoType errorInfoType;

	private static final String SVC_PREFIX = "SVC";
	private static final String POL_PREFIX = "POL";

	private static OnapLoggerError errLogger = OnapLoggerError.getInstance();
	private static OnapLoggerDebug debugLogger = OnapLoggerDebug.getInstance();


	public ErrorInfo() {
		this.errorInfoType = ErrorInfoType.OK;
	}

	public Integer getCode() {
		return code;
	}

	public void setCode(Integer code) {
		this.code = code;
	}

	public String getMessage() {
		return message;
	}

	public void setMessage(String message) {
		this.message = message;
	}

	public String getMessageId() {
		return messageId;
	}

	public void setMessageId(String messageId) {
		// Determining the type of error
		if (messageId == null || "200".equals(messageId) || "201".equals(messageId) || "204".equals(messageId)) {
			this.errorInfoType = ErrorInfoType.OK;
		} else if (messageId.startsWith(SVC_PREFIX)) {
			this.errorInfoType = ErrorInfoType.SERVICE_EXCEPTION;
		} else if (messageId.startsWith(POL_PREFIX)) {
			this.errorInfoType = ErrorInfoType.POLICY_EXCEPTION;
		} else {
			debugLogger.log(LogLevel.DEBUG, this.getClass().getName(), "Error: unexpected error message ID {}, should start with {} or {}", messageId, SVC_PREFIX, POL_PREFIX);
		}
		this.messageId = messageId;
	}

	public ErrorInfoType getErrorInfoType() {
		return this.errorInfoType;
	}

	public void cloneData(ErrorInfo other) {
		this.code = other.getCode();
		this.message = other.getMessage();
		this.messageId = other.getMessageId();
		this.errorInfoType = other.errorInfoType;
	}

	@Override
	public String toString() {
		return "ErrorInfo [code=" + code + ", messageId=" + messageId + ", message=" + message + "]";
	}

	public enum ErrorInfoType {
		OK, POLICY_EXCEPTION, SERVICE_EXCEPTION
	}

}