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