/*- * ============LICENSE_START======================================================= * VID * ================================================================================ * Copyright (C) 2017 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.openecomp.vid.conf; import java.util.ArrayList; import java.util.List; import javax.annotation.PostConstruct; import javax.sql.DataSource; import org.openecomp.vid.scheduler.RegistryAdapter; import org.openecomp.portalapp.uebhandler.InitUebHandler; import org.openecomp.portalapp.uebhandler.MainUebHandler; import org.openecomp.portalapp.uebhandler.WidgetNotificationHandler; import org.openecomp.portalsdk.core.conf.AppConfig; import org.openecomp.portalsdk.core.conf.Configurable; import org.openecomp.portalsdk.core.objectcache.AbstractCacheManager; import org.openecomp.portalsdk.core.service.DataAccessService; import org.openecomp.portalsdk.core.util.CacheManager; import org.openecomp.portalsdk.core.util.SystemProperties; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Value; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.ComponentScan; import org.springframework.context.annotation.Configuration; import org.springframework.context.annotation.Import; import org.springframework.context.annotation.Profile; import org.springframework.context.annotation.PropertySource; import org.springframework.context.support.PropertySourcesPlaceholderConfigurer; import org.springframework.core.io.Resource; import org.springframework.jdbc.datasource.init.DataSourceInitializer; import org.springframework.jdbc.datasource.init.DatabasePopulator; import org.springframework.jdbc.datasource.init.ResourceDatabasePopulator; import org.springframework.scheduling.annotation.EnableAsync; import org.springframework.scheduling.annotation.EnableScheduling; import org.springframework.scheduling.quartz.SchedulerFactoryBean; import org.springframework.web.servlet.ViewResolver; import org.springframework.web.servlet.config.annotation.EnableWebMvc; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry; import org.openecomp.portalsdk.core.logging.logic.EELFLoggerDelegate; /** * Configures Spring features in the ECOMP Portal SDK sample application. * Subclasses the ECOMP Portal SDK core AppConfig class to reuse interceptors, * view resolvers and other features defined there. */ @Configuration @EnableWebMvc @ComponentScan(basePackages = "org.openecomp") @PropertySource(value = { "${container.classpath:}/WEB-INF/conf/app/test.properties" }, ignoreResourceNotFound = true) @Profile("src") @EnableAsync @EnableScheduling public class ExternalAppConfig extends AppConfig implements Configurable { /** The Constant LOG. */ private static final EELFLoggerDelegate LOG = EELFLoggerDelegate.getLogger(ExternalAppConfig.class); /** The scheduler registry adapter. */ private RegistryAdapter schedulerRegistryAdapter; /** The vid schema script. */ @Value("classpath:vid-schema.sql") private Resource vidSchemaScript; /** The vid data script. */ @Value("classpath:vid-data.sql") private Resource vidDataScript; /** * The Class InnerConfiguration. */ @Configuration @Import(SystemProperties.class) static class InnerConfiguration { } /** * View resolver. * * @return the view resolver * @see org.openecomp.portalsdk.core.conf.AppConfig#viewResolver() */ public ViewResolver viewResolver() { return super.viewResolver(); } /** * Adds the resource handlers. * * @param registry the registry * @see org.openecomp.portalsdk.core.conf.AppConfig#addResourceHandlers(ResourceHandlerRegistry) */ public void addResourceHandlers(ResourceHandlerRegistry registry) { super.addResourceHandlers(registry); } /** * Data access service. * * @return the data access service * @see org.openecomp.portalsdk.core.conf.AppConfig#dataAccessService() */ public DataAccessService dataAccessService() { return super.dataAccessService(); } /** * Creates a new list with a single entry that is the external app * definitions.xml path. * * @return List of String, size 1 */ public List addTileDefinitions() { List definitions = new ArrayList(); definitions.add("/WEB-INF/defs/definitions.xml"); return definitions; } /** * Adds request interceptors to the specified registry by calling * {@link AppConfig#addInterceptors(InterceptorRegistry)}, but excludes * certain paths from the session timeout interceptor. * * @param registry the registry */ @Override public void addInterceptors(InterceptorRegistry registry) { super.setExcludeUrlPathsForSessionTimeout("/login_external", "*/login_external.htm", "login", "/login.htm", "/api*","/single_signon.htm","/single_signon"); super.addInterceptors(registry); } /** * Creates and returns a new instance of a {@link CacheManager} class. * * @return New instance of {@link CacheManager} */ @Bean public AbstractCacheManager cacheManager() { return new CacheManager(); } /** * Inits the global local context. */ @PostConstruct public void initGlobalLocalContext() { LOG.init(); } /** * Creates and returns a new instance of a {@link MainUebHandler}. * * @return New instance of {@link MainUebHandler}. */ @Bean public MainUebHandler mainUebHandler() { return new MainUebHandler(); } /** * Creates and returns a new instance of a {@link InitUebHandler}. * * @return New instance of {@link InitUebHandler}. */ @Bean public InitUebHandler initUebHandler() { return new InitUebHandler(); } /** * Creates and returns a new instance of a {@link WidgetNotificationHandler} * . * * @return New instance of {@link WidgetNotificationHandler}. */ @Bean public WidgetNotificationHandler widgetNotificationHandler() { return new WidgetNotificationHandler(); } /** * Creates and returns a new instance of a {@link SchedulerFactoryBean} and * populates it with triggers. * * @return New instance of {@link SchedulerFactoryBean} * @throws Exception the exception */ // @Bean // ANNOTATION COMMENTED OUT // APPLICATIONS REQUIRING QUARTZ SHOULD RESTORE ANNOTATION public SchedulerFactoryBean schedulerFactoryBean() throws Exception { SchedulerFactoryBean scheduler = new SchedulerFactoryBean(); scheduler.setTriggers(schedulerRegistryAdapter.getTriggers()); scheduler.setConfigLocation(appApplicationContext.getResource("WEB-INF/conf/quartz.properties")); scheduler.setDataSource(dataSource()); return scheduler; } /** * Data source initializer. * * @param dataSource the data source * @return the data source initializer */ @Bean public DataSourceInitializer dataSourceInitializer(DataSource dataSource) { LOG.info("Initializing VID data source"); final DataSourceInitializer initializer = new DataSourceInitializer(); initializer.setDataSource(dataSource); initializer.setDatabasePopulator(databasePopulator()); return initializer; } /** * Database populator. * * @return the database populator */ public DatabasePopulator databasePopulator() { LOG.info("Populating VID data source"); final ResourceDatabasePopulator populator = new ResourceDatabasePopulator(); populator.addScript(vidSchemaScript); populator.addScript(vidDataScript); return populator; } /** * Sets the scheduler registry adapter. * * @param schedulerRegistryAdapter the new scheduler registry adapter */ @Autowired public void setSchedulerRegistryAdapter(final RegistryAdapter schedulerRegistryAdapter) { this.schedulerRegistryAdapter = schedulerRegistryAdapter; } /** * Property config in dev. * * @return the property sources placeholder configurer */ @Bean public static PropertySourcesPlaceholderConfigurer propertyConfigInDev() { return new PropertySourcesPlaceholderConfigurer(); } }