Optionally disable client authentication
[aai/babel.git] / src / main / java / org / onap / aai / babel / BabelApplication.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 European Software Marketing Ltd.
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.aai.babel;
22
23 import java.util.HashMap;
24 import org.eclipse.jetty.util.security.Password;
25 import org.springframework.boot.autoconfigure.SpringBootApplication;
26 import org.springframework.boot.builder.SpringApplicationBuilder;
27 import org.springframework.boot.web.support.SpringBootServletInitializer;
28 import org.springframework.context.annotation.ImportResource;
29
30 @SpringBootApplication
31 @ImportResource("classpath:babel-beans.xml")
32 public class BabelApplication extends SpringBootServletInitializer {
33
34     private static final String OBFS_PATTERN = "OBF:";
35
36     /**
37      * Spring Boot Initialization.
38      * 
39      * @param args main args
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 IllegalArgumentException("Env property KEY_STORE_PASSWORD not set");
45         }
46         HashMap<String, Object> props = new HashMap<>();
47         String decryptedValue = keyStorePassword.startsWith(OBFS_PATTERN)? Password.deobfuscate(keyStorePassword) : keyStorePassword;
48         props.put("server.ssl.key-store-password", decryptedValue);
49
50         String requireClientAuth = System.getenv("REQUIRE_CLIENT_AUTH");
51         props.put("server.ssl.client-auth",
52                 Boolean.FALSE.toString().equalsIgnoreCase(requireClientAuth) ? "want" : "need");
53
54         new BabelApplication().configure(new SpringApplicationBuilder(BabelApplication.class).properties(props))
55                 .run(args);
56     }
57 }