2 * ============LICENSE_START=======================================================
3 * dcaegen2-collectors-veshv
4 * ================================================================================
5 * Copyright (C) 2018 NOKIA
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
20 package org.onap.dcae.collectors.veshv.utils.logging
22 import kotlin.reflect.KClass
23 import org.slf4j.LoggerFactory
26 typealias MappedDiagnosticContext = () -> Map<String, String>
28 @Suppress("TooManyFunctions", "SuboptimalLoggerUsage")
29 class Logger(logger: org.slf4j.Logger) {
30 constructor(clazz: KClass<out Any>) : this(LoggerFactory.getLogger(clazz.java))
31 constructor(name: String) : this(LoggerFactory.getLogger(name))
33 private val errorLogger = if (logger.isErrorEnabled) ErrorLevelLogger(logger) else OffLevelLogger
34 private val warnLogger = if (logger.isWarnEnabled) WarnLevelLogger(logger) else OffLevelLogger
35 private val infoLogger = if (logger.isInfoEnabled) InfoLevelLogger(logger) else OffLevelLogger
36 private val debugLogger = if (logger.isDebugEnabled) DebugLevelLogger(logger) else OffLevelLogger
37 private val traceLogger = if (logger.isTraceEnabled) TraceLevelLogger(logger) else OffLevelLogger
41 fun withError(block: AtLevelLogger.() -> Unit) = errorLogger.block()
43 fun withError(mdc: MappedDiagnosticContext, block: AtLevelLogger.() -> Unit) =
44 errorLogger.withMdc(mdc, block)
46 fun error(message: () -> String) = errorLogger.run {
50 fun error(mdc: MappedDiagnosticContext, message: () -> String) =
51 errorLogger.withMdc(mdc) { log(message()) }
53 fun error(mdc: MappedDiagnosticContext, marker: Marker, message: () -> String) =
54 errorLogger.withMdc(mdc) { log(marker, message()) }
58 fun withWarn(block: AtLevelLogger.() -> Unit) = warnLogger.block()
60 fun withWarn(mdc: MappedDiagnosticContext, block: AtLevelLogger.() -> Unit) =
61 warnLogger.withMdc(mdc, block)
63 fun warn(message: () -> String) = warnLogger.run {
67 fun warn(mdc: MappedDiagnosticContext, message: () -> String) =
68 warnLogger.withMdc(mdc) { log(message()) }
70 fun warn(mdc: MappedDiagnosticContext, marker: Marker, message: () -> String) =
71 warnLogger.withMdc(mdc) { log(marker, message()) }
75 fun withInfo(block: AtLevelLogger.() -> Unit) = infoLogger.block()
77 fun withInfo(mdc: MappedDiagnosticContext, block: AtLevelLogger.() -> Unit) =
78 infoLogger.withMdc(mdc, block)
80 fun info(message: () -> String) = infoLogger.run {
84 fun info(mdc: MappedDiagnosticContext, message: () -> String) =
85 infoLogger.withMdc(mdc) { log(message()) }
87 fun info(mdc: MappedDiagnosticContext, marker: Marker, message: () -> String) =
88 infoLogger.withMdc(mdc) { log(marker, message()) }
92 fun withDebug(block: AtLevelLogger.() -> Unit) = debugLogger.block()
94 fun withDebug(mdc: MappedDiagnosticContext, block: AtLevelLogger.() -> Unit) =
95 debugLogger.withMdc(mdc, block)
97 fun debug(message: () -> String) = debugLogger.run {
101 fun debug(mdc: MappedDiagnosticContext, message: () -> String) =
102 debugLogger.withMdc(mdc) { log(message()) }
104 fun debug(mdc: MappedDiagnosticContext, marker: Marker, message: () -> String) =
105 debugLogger.withMdc(mdc) { log(marker, message()) }
109 fun withTrace(block: AtLevelLogger.() -> Unit) = traceLogger.block()
111 fun withTrace(mdc: MappedDiagnosticContext, block: AtLevelLogger.() -> Unit) =
112 traceLogger.withMdc(mdc, block)
114 fun trace(message: () -> String) = traceLogger.run {
118 fun trace(mdc: MappedDiagnosticContext, message: () -> String) =
119 traceLogger.withMdc(mdc) { log(message()) }
121 fun trace(mdc: MappedDiagnosticContext, marker: Marker, message: () -> String) =
122 traceLogger.withMdc(mdc) { log(marker, message()) }
126 abstract class AtLevelLogger {
127 abstract fun log(message: String)
128 abstract fun log(message: String, t: Throwable)
129 abstract fun log(marker: Marker, message: String)
130 open val enabled: Boolean
133 inline fun withMdc(mdc: MappedDiagnosticContext, block: AtLevelLogger.() -> Unit) {
136 MDC.setContextMap(mdc())
145 object OffLevelLogger : AtLevelLogger() {
146 override val enabled = false
148 override fun log(message: String) {
149 // do not log anything
152 override fun log(message: String, t: Throwable) {
153 // do not log anything
156 override fun log(marker: Marker, message: String) {
157 // do not log anything
161 @Suppress("SuboptimalLoggerUsage")
162 class ErrorLevelLogger(private val logger: org.slf4j.Logger) : AtLevelLogger() {
163 override fun log(message: String) {
164 logger.error(message)
167 override fun log(message: String, t: Throwable) {
168 logger.error(message, t)
171 override fun log(marker: Marker, message: String) {
172 logger.error(marker(), message)
176 @Suppress("SuboptimalLoggerUsage")
177 class WarnLevelLogger(private val logger: org.slf4j.Logger) : AtLevelLogger() {
178 override fun log(message: String) {
182 override fun log(message: String, t: Throwable) {
183 logger.warn(message, t)
186 override fun log(marker: Marker, message: String) {
187 logger.warn(marker(), message)
191 @Suppress("SuboptimalLoggerUsage")
192 class InfoLevelLogger(private val logger: org.slf4j.Logger) : AtLevelLogger() {
193 override fun log(message: String) {
197 override fun log(message: String, t: Throwable) {
198 logger.info(message, t)
201 override fun log(marker: Marker, message: String) {
202 logger.info(marker(), message)
206 @Suppress("SuboptimalLoggerUsage")
207 class DebugLevelLogger(private val logger: org.slf4j.Logger) : AtLevelLogger() {
208 override fun log(message: String) {
209 logger.debug(message)
212 override fun log(message: String, t: Throwable) {
213 logger.debug(message, t)
216 override fun log(marker: Marker, message: String) {
217 logger.debug(marker(), message)
221 @Suppress("SuboptimalLoggerUsage")
222 class TraceLevelLogger(private val logger: org.slf4j.Logger) : AtLevelLogger() {
223 override fun log(message: String) {
224 logger.trace(message)
227 override fun log(message: String, t: Throwable) {
228 logger.trace(message, t)
231 override fun log(marker: Marker, message: String) {
232 logger.trace(marker(), message)