/* * ============LICENSE_START======================================================= * dcaegen2-collectors-veshv * ================================================================================ * Copyright (C) 2018 NOKIA * ================================================================================ * 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.collectors.veshv.utils.logging import arrow.core.Either import arrow.core.Option import arrow.core.Try import reactor.core.publisher.Flux import reactor.core.publisher.Mono fun Logger.handleReactiveStreamError(ex: Throwable, returnFlux: Flux = Flux.empty()): Flux { logger.warn("Error while handling message stream: ${ex::class.qualifiedName} (${ex.localizedMessage})") logger.debug("Detailed stack trace", ex) return returnFlux } fun Try.filterFailedWithLog(logger: Logger, acceptedMsg: (T) -> String, rejectedMsg: (Throwable) -> String): Flux = fold({ logger.warn(rejectedMsg(it)) Flux.empty() }, { logger.trace { acceptedMsg(it) } Flux.just(it) }) fun Option.filterEmptyWithLog(logger: Logger, acceptedMsg: (T) -> String, rejectedMsg: () -> String): Flux = fold({ logger.warn(rejectedMsg) Flux.empty() }, { logger.trace { acceptedMsg(it) } Flux.just(it) }) fun Flux.filterFailedWithLog(logger: Logger, predicate: (T) -> Either<() -> String, () -> String>) = flatMap { t -> predicate(t).fold({ logger.warn(it) Mono.empty() }, { logger.trace(it) Mono.just(t) }) }