Custom detekt rule for logger usage check
[dcaegen2/collectors/hv-ves.git] / sources / hv-collector-ssl / src / main / kotlin / org / onap / dcae / collectors / veshv / ssl / impl / SslFactories.kt
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.ssl.impl
21
22 import org.onap.dcae.collectors.veshv.domain.JdkKeys
23 import org.onap.dcae.collectors.veshv.domain.StreamProvider
24 import java.security.KeyStore
25 import javax.net.ssl.KeyManagerFactory
26 import javax.net.ssl.TrustManagerFactory
27
28 /**
29  * @author Piotr Jaszczyk <piotr.jaszczyk@nokia.com>
30  * @since September 2018
31  */
32 internal object SslFactories {
33
34     fun trustManagerFactory(jdkKeys: JdkKeys): TrustManagerFactory? {
35         val tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm())
36         val ts = loadKeyStoreFromFile(jdkKeys.trustStore, jdkKeys.trustStorePassword)
37         tmf.init(ts)
38         return tmf
39     }
40
41     fun keyManagerFactory(jdkKeys: JdkKeys): KeyManagerFactory? {
42         val kmf = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm())
43         val ks = loadKeyStoreFromFile(jdkKeys.keyStore, jdkKeys.keyStorePassword)
44         kmf.init(ks, jdkKeys.keyStorePassword)
45         return kmf
46     }
47
48     private fun loadKeyStoreFromFile(streamProvider: StreamProvider, password: CharArray): KeyStore {
49         val ks = KeyStore.getInstance("pkcs12")
50         streamProvider().use {
51             ks.load(it, password)
52         }
53         return ks
54     }
55 }