4d65e916bef1771a8612ddd54fa90d087f0b0152
[dcaegen2/collectors/hv-ves.git] /
1 /*
2 * ============LICENSE_START=======================================================
3 * dcaegen2-collectors-veshv
4 * ================================================================================
5 * Copyright (C) 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.kafkaconsumer.config
21
22 import arrow.core.Option
23 import org.apache.commons.cli.CommandLine
24 import org.apache.commons.cli.DefaultParser
25 import org.onap.dcae.collectors.veshv.commandline.ArgBasedConfiguration
26 import org.onap.dcae.collectors.veshv.commandline.CommandLineOption
27 import org.onap.dcae.collectors.veshv.commandline.CommandLineOption.LISTEN_PORT
28 import org.onap.dcae.collectors.veshv.commandline.intValue
29 import org.onap.dcae.collectors.veshv.utils.arrow.OptionUtils.binding
30 import java.net.InetSocketAddress
31
32 internal class ArgKafkaConsumerConfiguration : ArgBasedConfiguration<KafkaConsumerConfiguration>(DefaultParser()) {
33     override val cmdLineOptionsList: List<CommandLineOption> = listOf(LISTEN_PORT)
34
35     override fun getConfiguration(cmdLine: CommandLine): Option<KafkaConsumerConfiguration> =
36             binding {
37                 val listenPort = cmdLine.intValue(LISTEN_PORT).bind()
38                 KafkaConsumerConfiguration(InetSocketAddress(listenPort))
39             }
40 }