Merge "Extract transforming logic from validator"
[dcaegen2/collectors/hv-ves.git] / sources / hv-collector-domain / src / main / kotlin / org / onap / dcae / collectors / veshv / domain / logging / ClientContextLogging.kt
1 /*
2  * ============LICENSE_START=======================================================
3  * dcaegen2-collectors-veshv
4  * ================================================================================
5  * Copyright (C) 2018-2019 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
10  *
11  *      http://www.apache.org/licenses/LICENSE-2.0
12  *
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=========================================================
19  */
20 package org.onap.dcae.collectors.veshv.domain.logging
21
22 import org.onap.dcae.collectors.veshv.utils.logging.AtLevelLogger
23 import org.onap.dcae.collectors.veshv.utils.logging.Logger
24 import org.onap.dcae.collectors.veshv.utils.logging.handleReactiveStreamError
25 import reactor.core.publisher.Flux
26
27 @Suppress("TooManyFunctions")
28 object ClientContextLogging {
29     fun Logger.withError(ctx: ClientContext, block: AtLevelLogger.() -> Unit) = withError(ctx::fullMdc, block)
30     fun Logger.withWarn(ctx: ClientContext, block: AtLevelLogger.() -> Unit) = withWarn(ctx::fullMdc, block)
31     fun Logger.withInfo(ctx: ClientContext, block: AtLevelLogger.() -> Unit) = withInfo(ctx::fullMdc, block)
32     fun Logger.withDebug(ctx: ClientContext, block: AtLevelLogger.() -> Unit) = withDebug(ctx::fullMdc, block)
33     fun Logger.withTrace(ctx: ClientContext, block: AtLevelLogger.() -> Unit) = withTrace(ctx::fullMdc, block)
34
35     fun Logger.error(ctx: ClientContext, message: () -> String) = error(ctx::fullMdc, message)
36     fun Logger.warn(ctx: ClientContext, message: () -> String) = warn(ctx::fullMdc, message)
37     fun Logger.info(ctx: ClientContext, message: () -> String) = info(ctx::fullMdc, message)
38     fun Logger.debug(ctx: ClientContext, message: () -> String) = debug(ctx::fullMdc, message)
39     fun Logger.trace(ctx: ClientContext, message: () -> String) = trace(ctx::fullMdc, message)
40
41     fun <T> Logger.handleReactiveStreamError(context: ClientContext, ex: Throwable,
42                                              returnFlux: Flux<T> = Flux.empty()): Flux<T> {
43         return this.handleReactiveStreamError({ context.fullMdc }, ex, returnFlux)
44     }
45 }
46