aboutsummaryrefslogtreecommitdiffstats
path: root/dmaap-bc/src/main/java/org/onap/dmaap/dbcapi/server/CadiCertificateManager.java
blob: 1da2bc4a37a4975111036cbcac785c83947d8990 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*-
 * ============LICENSE_START=======================================================
 * org.onap.dmaap
 * ================================================================================
 * Copyright (C) 2020 AT&T Intellectual Property. All rights reserved.
 * ================================================================================
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * ============LICENSE_END=========================================================
 */
package org.onap.dmaap.dbcapi.server;

import java.io.FileInputStream;
import java.io.IOException;
import java.util.Properties;

import org.onap.aaf.cadi.PropAccess;

public class CadiCertificateManager extends CertificateManager {
	private PropAccess propAccess;	
	
	CadiCertificateManager( Properties properties )  {
		String cadiPropsFile = properties.getProperty("cadi.properties", "etc/org.onap.dmaa-bc.props");
		logger.info( "using cadi properties in ", cadiPropsFile);
		
		propAccess = new PropAccess();
		ready = true;
		try {
			propAccess.load( new FileInputStream( cadiPropsFile ));
		} catch ( IOException e ) {
			logger.error( "Failed to load props file: " + cadiPropsFile + "\n" +  e.getMessage());
			ready = false;
		}
		setKeyStoreType( "jks");
		setKeyStoreFile( propAccess.getProperty("cadi_keystore") );
		setKeyStorePassword( decryptPass( propAccess.getProperty("cadi_keystore_password_jks" ) ));

		setTrustStoreType( "jks");
		setTrustStoreFile( propAccess.getProperty("cadi_truststore" ) );
		setTrustStorePassword( decryptPass( propAccess.getProperty("cadi_truststore_password" ) ));
	}

	private String decryptPass( String password ) {
		String clear = null;
		try {
			clear = propAccess.decrypt(password, false );
		} catch (IOException e) {
			logger.error( "Failed to decrypt " + password + ": " + e.getMessage() );
		}
		return clear;
	}
}