f318cad50287b310f9a76ea5c37b47283db8a204
[portal/ric-dashboard.git] / webapp-backend / src / main / java / org / oransc / ric / portal / dashboard / config / PortalApiConfiguration.java
1 /*-
2  * ========================LICENSE_START=================================
3  * O-RAN-SC
4  * %%
5  * Copyright (C) 2019 AT&T Intellectual Property
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.oransc.ric.portal.dashboard.config;
21
22 import java.lang.invoke.MethodHandles;
23
24 import org.onap.portalsdk.core.onboarding.crossapi.PortalRestAPIProxy;
25 import org.onap.portalsdk.core.onboarding.util.PortalApiConstants;
26 import org.slf4j.Logger;
27 import org.slf4j.LoggerFactory;
28 import org.springframework.boot.web.servlet.ServletRegistrationBean;
29 import org.springframework.context.annotation.Bean;
30 import org.springframework.context.annotation.Configuration;
31 import org.springframework.context.annotation.Profile;
32
33 @Configuration
34 @Profile("!test")
35 public class PortalApiConfiguration {
36
37         private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
38
39         /**
40          * Instantiates the EPSDK-FW servlet that implements the API called by Portal.
41          * Needed because this app is not configured to scan the EPSDK-FW packages;
42          * there's also a chance that Spring-Boot does not automatically
43          * process @WebServlet annotations.
44          * 
45          * @return Servlet registration bean for the Portal Rest API proxy servlet.
46          */
47         @Bean
48         public ServletRegistrationBean<PortalRestAPIProxy> portalApiProxyServletBean() {
49                 logger.debug("portalApiProxyServletBean");
50                 PortalRestAPIProxy servlet = new PortalRestAPIProxy();
51                 final ServletRegistrationBean<PortalRestAPIProxy> servletBean = new ServletRegistrationBean<>(servlet,
52                                 PortalApiConstants.API_PREFIX + "/*");
53                 servletBean.setName("PortalRestApiProxyServlet");
54                 return servletBean;
55         }
56
57 }