2 * ============LICENSE_START=======================================================
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
12 * http://www.apache.org/licenses/LICENSE-2.0
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=========================================================
21 package org.onap.crud;
23 import java.util.Collections;
24 import java.util.HashMap;
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 import springfox.documentation.builders.PathSelectors;
34 import springfox.documentation.builders.RequestHandlerSelectors;
35 import springfox.documentation.service.ApiInfo;
36 import springfox.documentation.service.Contact;
37 import springfox.documentation.spi.DocumentationType;
38 import springfox.documentation.spring.web.plugins.Docket;
39 import springfox.documentation.swagger2.annotations.EnableSwagger2;
42 * Crud application class - SpringApplication.run
44 @SpringBootApplication
46 @ImportResource({"file:${SERVICE_BEANS}/*.xml"})
47 public class CrudApplication extends SpringBootServletInitializer{// NOSONAR
49 private Environment env;
51 public static void main(String[] args) {// NOSONAR
52 String keyStorePassword = System.getProperty("KEY_STORE_PASSWORD");
53 if(keyStorePassword==null || keyStorePassword.isEmpty()){
54 throw new RuntimeException("Env property KEY_STORE_PASSWORD not set");
56 HashMap<String, Object> props = new HashMap<>();
57 String deobfuscatedKeyStorePassword = keyStorePassword.startsWith("OBF:")?Password.deobfuscate(keyStorePassword):keyStorePassword;
58 props.put("server.ssl.key-store-password", deobfuscatedKeyStorePassword);
60 String trustStoreLocation = System.getProperty("TRUST_STORE_LOCATION");
61 String trustStorePassword = System.getProperty("TRUST_STORE_PASSWORD");
62 if(trustStoreLocation!=null && trustStorePassword !=null){
63 trustStorePassword = trustStorePassword.startsWith("OBF:")?Password.deobfuscate(trustStorePassword):trustStorePassword;
64 props.put("server.ssl.trust-store", trustStoreLocation);
65 props.put("server.ssl.trust-store-password", trustStorePassword);
68 String authLevel = System.getenv("SSL_CLIENT_AUTH");
69 if (authLevel == null || authLevel.isEmpty()) {
70 props.put("server.ssl.client-auth", "need");
72 props.put("server.ssl.client-auth",authLevel);
76 props.put("schema.service.ssl.key-store-password", deobfuscatedKeyStorePassword);
77 props.put("schema.service.ssl.trust-store-password", deobfuscatedKeyStorePassword);
79 String requireClientAuth = System.getenv("REQUIRE_CLIENT_AUTH");
80 if (requireClientAuth == null || requireClientAuth.isEmpty()) {
81 props.put("server.ssl.client-auth", "need");
83 props.put("server.ssl.client-auth",requireClientAuth.equals("true")?"need":"want");
87 .configure(new SpringApplicationBuilder(CrudApplication.class).properties(props))
92 * Set required trust store system properties using values from application.properties
95 public void setSystemProperties() {
96 String trustStorePath = env.getProperty("server.ssl.key-store");
97 if (trustStorePath != null) {
98 String trustStorePassword = env.getProperty("server.ssl.key-store-password");
100 if (trustStorePassword != null) {
101 System.setProperty("javax.net.ssl.trustStore", trustStorePath);
102 System.setProperty("javax.net.ssl.trustStorePassword", trustStorePassword);
104 throw new IllegalArgumentException("Env property server.ssl.key-store-password not set");
108 public static final Contact DEFAULT_CONTACT = new Contact("Amdocs", "http://www.amdocs.com", "noreply@amdocs.com");
110 public static final ApiInfo DEFAULT_API_INFO = new ApiInfo("AAI Gizmo Service", "AAI Gizmo Service.",
111 "1.0", "urn:tos", DEFAULT_CONTACT, "Apache 2.0", "API license URL", Collections.emptyList());
113 public Docket api() {
114 return new Docket(DocumentationType.SWAGGER_2).apiInfo(DEFAULT_API_INFO).select().paths(PathSelectors.any())
115 .apis(RequestHandlerSelectors.basePackage("org.onap.crud")).build();