Bump checkstyle version
[dcaegen2/collectors/hv-ves.git] / hv-collector-utils / src / main / kotlin / org / onap / dcae / collectors / veshv / utils / arrow / effects.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.utils.arrow
21
22 import arrow.core.Either
23 import arrow.core.Left
24 import arrow.core.Right
25 import arrow.effects.IO
26 import reactor.core.publisher.Flux
27 import reactor.core.publisher.Mono
28 import kotlin.system.exitProcess
29
30 /**
31  * @author Piotr Jaszczyk <piotr.jaszczyk@nokia.com>
32  * @since June 2018
33  */
34
35 sealed class ExitCode {
36     abstract val code: Int
37
38     fun io() = IO {
39         exitProcess(code)
40     }
41 }
42
43 object ExitSuccess : ExitCode() {
44     override val code = 0
45 }
46
47 data class ExitFailure(override val code: Int) : ExitCode()
48
49 fun Either<IO<Unit>, IO<Unit>>.unsafeRunEitherSync(onError: (Throwable) -> ExitCode, onSuccess: () -> Unit) =
50         flatten().attempt().unsafeRunSync().fold({ onError(it).io().unsafeRunSync() }, { onSuccess() })
51
52
53 fun IO<Any>.unit() = map { Unit }
54
55 fun <T> Mono<T>.asIo() = IO.async<T> { callback ->
56     subscribe({
57         callback(Right(it))
58     }, {
59         callback(Left(it))
60     })
61 }
62
63 fun <T> Flux<IO<T>>.evaluateIo(): Flux<T> =
64         flatMap { io ->
65             io.attempt().unsafeRunSync().fold(
66                     { Flux.error<T>(it) },
67                     { Flux.just<T>(it) }
68             )
69         }