Merge "Extract transforming logic from validator"
[dcaegen2/collectors/hv-ves.git] / sources / hv-collector-server / src / main / kotlin / org / onap / dcae / collectors / veshv / impl / HvVesServer.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.impl
21
22 import org.onap.dcae.collectors.veshv.api.Server
23 import org.onap.dcae.collectors.veshv.config.api.model.HvVesConfiguration
24 import org.onap.dcae.collectors.veshv.factory.HvVesCollectorFactory
25 import org.onap.dcae.collectors.veshv.factory.AdapterFactory
26 import org.onap.dcae.collectors.veshv.boundary.Metrics
27 import org.onap.dcae.collectors.veshv.ssl.boundary.SslContextFactory
28 import org.onap.dcae.collectors.veshv.domain.logging.ServiceContext
29 import org.onap.dcae.collectors.veshv.utils.ServerHandle
30 import org.onap.dcae.collectors.veshv.utils.logging.Logger
31 import reactor.core.publisher.Mono
32
33 /**
34  * @author Piotr Jaszczyk <piotr.jaszczyk@nokia.com>
35  * @since August 2018
36  */
37 internal class HvVesServer(private val config: HvVesConfiguration,
38                            private val sslFactory: SslContextFactory,
39                            private val metrics: Metrics) : Server {
40
41     private val logger = Logger(HvVesServer::class)
42
43     override fun start(): Mono<ServerHandle> =
44             createNettyTcpServer(config)
45                     .start()
46                     .doOnNext(::logServerStarted)
47
48     private fun createNettyTcpServer(config: HvVesConfiguration): Server =
49             NettyTcpServer(
50                     config.server,
51                     sslFactory.createServerContext(config.security),
52                     createCollectorProvider(config),
53                     metrics
54             )
55
56     private fun createCollectorProvider(config: HvVesConfiguration): HvVesCollectorFactory =
57             HvVesCollectorFactory(
58                     config.collector,
59                     AdapterFactory.sinkCreatorFactory(),
60                     metrics
61             )
62
63     private fun logServerStarted(handle: ServerHandle) =
64             logger.info(ServiceContext::mdc) {
65                 "HighVolume VES Collector is up and listening on ${handle.host}:${handle.port}"
66             }
67 }