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