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
11 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
20 package org.onap.dcae.collectors.veshv.simulators.xnf.config
22 import arrow.core.ForOption
23 import arrow.core.Option
25 import arrow.instances.extensions
26 import arrow.typeclasses.binding
27 import org.apache.commons.cli.CommandLine
28 import org.apache.commons.cli.DefaultParser
29 import org.onap.dcae.collectors.veshv.domain.SecurityConfiguration
30 import org.onap.dcae.collectors.veshv.utils.commandline.ArgBasedConfiguration
31 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.*
35 * @author Jakub Dudycz <jakub.dudycz@nokia.com>
38 internal class ArgXnfSimulatorConfiguration : ArgBasedConfiguration<SimulatorConfiguration>(DefaultParser()) {
39 override val cmdLineOptionsList = listOf(
49 override fun getConfiguration(cmdLine: CommandLine): Option<SimulatorConfiguration> =
50 ForOption extensions {
52 val listenPort = cmdLine.intValue(LISTEN_PORT).bind()
53 val vesHost = cmdLine.stringValue(VES_HV_HOST).bind()
54 val vesPort = cmdLine.intValue(VES_HV_PORT).bind()
56 SimulatorConfiguration(
60 parseSecurityConfig(cmdLine))
64 private fun parseSecurityConfig(cmdLine: CommandLine): SecurityConfiguration {
65 val sslDisable = cmdLine.hasOption(SSL_DISABLE)
66 val pkFile = cmdLine.stringValue(PRIVATE_KEY_FILE, DefaultValues.PRIVATE_KEY_FILE)
67 val certFile = cmdLine.stringValue(CERT_FILE, DefaultValues.CERT_FILE)
68 val trustCertFile = cmdLine.stringValue(TRUST_CERT_FILE, DefaultValues.TRUST_CERT_FILE)
70 return SecurityConfiguration(
71 sslDisable = sslDisable,
72 privateKey = stringPathToPath(pkFile),
73 cert = stringPathToPath(certFile),
74 trustedCert = stringPathToPath(trustCertFile))
77 internal object DefaultValues {
78 const val PRIVATE_KEY_FILE = "/etc/ves-hv/client.key"
79 const val CERT_FILE = "/etc/ves-hv/client.crt"
80 const val TRUST_CERT_FILE = "/etc/ves-hv/trust.crt"