f3e97be205f1803d851d557e033f14b235d04b57
[dcaegen2/collectors/hv-ves.git] /
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.main
21
22 import org.apache.commons.cli.CommandLine
23 import org.apache.commons.cli.DefaultParser
24 import org.onap.dcae.collectors.veshv.domain.SecurityConfiguration
25 import org.onap.dcae.collectors.veshv.model.ServerConfiguration
26 import org.onap.dcae.collectors.veshv.utils.commandline.ArgBasedConfiguration
27 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.CERT_FILE
28 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.CONSUL_CONFIG_URL
29 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.DUMMY_MODE
30 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.IDLE_TIMEOUT_SEC
31 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.LISTEN_PORT
32 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.PRIVATE_KEY_FILE
33 import org.onap.dcae.collectors.veshv.utils.commandline.CommandLineOption.TRUST_CERT_FILE
34 import java.time.Duration
35
36 internal object DefaultValues {
37     const val PORT = 6061
38     const val CONFIG_URL = ""
39     const val PRIVATE_KEY_FILE = "/etc/ves-hv/server.key"
40     const val CERT_FILE = "/etc/ves-hv/server.crt"
41     const val TRUST_CERT_FILE = "/etc/ves-hv/trust.crt"
42     const val IDLE_TIMEOUT_SEC = 60L
43 }
44
45 internal class ArgBasedServerConfiguration : ArgBasedConfiguration<ServerConfiguration>(DefaultParser()) {
46     override val cmdLineOptionsList = listOf(
47             LISTEN_PORT,
48             CONSUL_CONFIG_URL,
49             PRIVATE_KEY_FILE,
50             CERT_FILE,
51             TRUST_CERT_FILE,
52             IDLE_TIMEOUT_SEC,
53             DUMMY_MODE
54     )
55
56     override fun getConfiguration(cmdLine: CommandLine): ServerConfiguration {
57         val port = cmdLine.intValue(LISTEN_PORT, DefaultValues.PORT)
58         val configUrl = cmdLine.stringValue(CONSUL_CONFIG_URL, DefaultValues.CONFIG_URL)
59         val idleTimeoutSec = cmdLine.longValue(IDLE_TIMEOUT_SEC, DefaultValues.IDLE_TIMEOUT_SEC)
60         val dummyMode = cmdLine.hasOption(DUMMY_MODE)
61         val security = createSecurityConfiguration(cmdLine)
62         return ServerConfiguration(
63                 port = port,
64                 configurationUrl = configUrl,
65                 securityConfiguration = security,
66                 idleTimeout = Duration.ofSeconds(idleTimeoutSec),
67                 dummyMode = dummyMode)
68     }
69
70     private fun createSecurityConfiguration(cmdLine: CommandLine): SecurityConfiguration {
71         val pkFile = cmdLine.stringValue(PRIVATE_KEY_FILE, DefaultValues.PRIVATE_KEY_FILE)
72         val certFile = cmdLine.stringValue(CERT_FILE, DefaultValues.CERT_FILE)
73         val trustCertFile = cmdLine.stringValue(TRUST_CERT_FILE, DefaultValues.TRUST_CERT_FILE)
74
75         return SecurityConfiguration(
76                 privateKey = stringPathToPath(pkFile),
77                 cert = stringPathToPath(certFile),
78                 trustedCert = stringPathToPath(trustCertFile)
79         )
80     }
81 }