Merge "Added sonar fixes"
[aai/champ.git] / champ-service / src / main / java / org / onap / champ / ChampApplication.java
1 /**
2  * ============LICENSE_START==========================================
3  * org.onap.aai
4  * ===================================================================
5  * Copyright Â© 2017-2018 AT&T Intellectual Property. All rights reserved.
6  * Copyright Â© 2017-2018 Amdocs
7  * ===================================================================
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  *     http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  * ============LICENSE_END============================================
20  */
21 package org.onap.champ;
22
23 import java.util.HashMap;
24 import java.util.Map;
25 import javax.annotation.PostConstruct;
26 import org.eclipse.jetty.util.security.Password;
27 import org.springframework.beans.factory.annotation.Autowired;
28 import org.springframework.boot.autoconfigure.SpringBootApplication;
29 import org.springframework.boot.builder.SpringApplicationBuilder;
30 import org.springframework.boot.web.support.SpringBootServletInitializer;
31 import org.springframework.context.annotation.ImportResource;
32 import org.springframework.core.env.Environment;
33
34 @SpringBootApplication
35 @ImportResource({"file:${SERVICE_BEANS}/*.xml"})
36 public class ChampApplication extends SpringBootServletInitializer {
37
38     @Autowired
39     private Environment env;
40
41     public static void main(String[] args) {
42         String keyStorePassword = System.getProperty("KEY_STORE_PASSWORD");
43         if (keyStorePassword == null || keyStorePassword.isEmpty()) {
44             throw new RuntimeException("Environment property KEY_STORE_PASSWORD not set");
45         }
46
47         Map<String, Object> props = new HashMap<>();
48         String deobfuscatedKeyStorePassword = keyStorePassword.startsWith("OBF:") ? Password.deobfuscate(keyStorePassword) : keyStorePassword;
49         props.put("server.ssl.key-store-password", deobfuscatedKeyStorePassword);
50
51         String trustStoreLocation = System.getProperty("TRUST_STORE_LOCATION");
52         String trustStorePassword = System.getProperty("TRUST_STORE_PASSWORD");
53         if (trustStoreLocation != null && trustStorePassword != null) {
54             trustStorePassword = trustStorePassword.startsWith("OBF:") ? Password.deobfuscate(trustStorePassword) : trustStorePassword;
55             props.put("server.ssl.trust-store", trustStoreLocation);
56             props.put("server.ssl.trust-store-password", trustStorePassword);
57         }
58
59         String requireClientAuth = System.getenv("REQUIRE_CLIENT_AUTH");
60         if (requireClientAuth == null || requireClientAuth.isEmpty()) {
61             props.put("server.ssl.client-auth", "need");
62         }else {
63             props.put("server.ssl.client-auth",requireClientAuth.equals("true")?"need":"want");
64         }       
65
66         new ChampApplication().configure(new SpringApplicationBuilder(ChampApplication.class).properties(props))
67                 .run(args);
68     }
69
70     /**
71      * Set required trust store system properties using values from application.properties
72      */
73     @PostConstruct
74     public void setSystemProperties() {
75         String trustStorePath = env.getProperty("server.ssl.key-store");
76         if (trustStorePath != null) {
77             String trustStorePassword = env.getProperty("server.ssl.key-store-password");
78
79             if (trustStorePassword != null) {
80                 System.setProperty("javax.net.ssl.trustStore", trustStorePath);
81                 System.setProperty("javax.net.ssl.trustStorePassword", trustStorePassword);
82             } else {
83                 throw new IllegalArgumentException("Env property server.ssl.key-store-password not set");
84             }
85         }
86     }
87 }