Coverage Report - org.kuali.rice.core.impl.config.module.ModuleConfigurer
 
Classes in this File Line Coverage Branch Coverage Complexity
ModuleConfigurer
0%
0/121
0%
0/34
1.467
 
 1  
 /*
 2  
  * Copyright 2006-2011 The Kuali Foundation
 3  
  *
 4  
  * Licensed under the Educational Community License, Version 2.0 (the "License");
 5  
  * you may not use this file except in compliance with the License.
 6  
  * You may obtain a copy of the License at
 7  
  *
 8  
  * http://www.opensource.org/licenses/ecl2.php
 9  
  *
 10  
  * Unless required by applicable law or agreed to in writing, software
 11  
  * distributed under the License is distributed on an "AS IS" BASIS,
 12  
  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 13  
  * See the License for the specific language governing permissions and
 14  
  * limitations under the License.
 15  
  */
 16  
 
 17  
 package org.kuali.rice.core.impl.config.module;
 18  
 
 19  
 import java.util.ArrayList;
 20  
 import java.util.Arrays;
 21  
 import java.util.Collection;
 22  
 import java.util.Collections;
 23  
 import java.util.List;
 24  
 import java.util.Properties;
 25  
 
 26  
 import javax.servlet.ServletContext;
 27  
 import javax.xml.namespace.QName;
 28  
 
 29  
 import org.apache.commons.collections.CollectionUtils;
 30  
 import org.apache.commons.lang.StringUtils;
 31  
 import org.apache.log4j.Logger;
 32  
 import org.kuali.rice.core.api.config.ConfigurationException;
 33  
 import org.kuali.rice.core.api.config.CoreConfigHelper;
 34  
 import org.kuali.rice.core.api.config.module.Configurer;
 35  
 import org.kuali.rice.core.api.config.module.RunMode;
 36  
 import org.kuali.rice.core.api.config.property.ConfigContext;
 37  
 import org.kuali.rice.core.api.lifecycle.BaseCompositeLifecycle;
 38  
 import org.kuali.rice.core.api.lifecycle.Lifecycle;
 39  
 import org.kuali.rice.core.api.resourceloader.GlobalResourceLoader;
 40  
 import org.kuali.rice.core.api.resourceloader.ResourceLoader;
 41  
 import org.kuali.rice.core.api.resourceloader.ResourceLoaderContainer;
 42  
 import org.kuali.rice.core.framework.resourceloader.BaseResourceLoader;
 43  
 import org.kuali.rice.core.impl.resourceloader.RiceResourceLoaderFactory;
 44  
 import org.kuali.rice.core.util.RiceConstants;
 45  
 import org.springframework.beans.factory.DisposableBean;
 46  
 import org.springframework.beans.factory.InitializingBean;
 47  
 import org.springframework.context.ApplicationEvent;
 48  
 import org.springframework.context.ApplicationListener;
 49  
 import org.springframework.context.event.ContextClosedEvent;
 50  
 import org.springframework.context.event.ContextRefreshedEvent;
 51  
 import org.springframework.web.context.ServletContextAware;
 52  
 
 53  
 // FIXME: this class must be put in an API module somehow
 54  
 public class ModuleConfigurer extends BaseCompositeLifecycle implements Configurer, InitializingBean, DisposableBean, ApplicationListener<ApplicationEvent>, ServletContextAware {
 55  0
     protected final Logger LOG = Logger.getLogger(getClass());
 56  
 
 57  0
     private List<RunMode> validRunModes = new ArrayList<RunMode>();
 58  
         private boolean hasWebInterface;
 59  
         
 60  0
         private Properties properties = new Properties();
 61  
         private String moduleName;
 62  
         private ServletContext servletContext;
 63  
         
 64  0
         public ModuleConfigurer() {
 65  0
         }
 66  
         
 67  0
         public ModuleConfigurer(String moduleName) {
 68  0
                 this.moduleName = moduleName;
 69  0
         }
 70  
         
 71  
         @Override
 72  
         public final void start() throws Exception {
 73  0
                 super.start();
 74  0
                 doAdditionalModuleStartLogic();
 75  0
         }
 76  
         
 77  
         protected void doAdditionalModuleStartLogic() throws Exception {
 78  
                 // subclass can override if needed
 79  0
         }
 80  
         
 81  
         @Override
 82  
         public final void afterPropertiesSet() throws Exception {
 83  0
                 validateConfigurerState();
 84  0
                 addToConfig();
 85  0
                 initializeResourceLoaders();
 86  0
                 start();
 87  0
         }
 88  
         
 89  
         @Override
 90  
         public final void stop() throws Exception {
 91  
                 try {
 92  0
                         doAdditionalModuleStopLogic();
 93  
                 } finally {
 94  0
                         super.stop();
 95  0
                 }
 96  0
         }
 97  
         
 98  
         protected void doAdditionalModuleStopLogic() throws Exception {
 99  
                 // subclass can override if needed
 100  0
         }
 101  
         
 102  
         @Override
 103  
         public final void destroy() throws Exception {
 104  0
         stop();
 105  
         //FIXME: attempting to see if this fixes the ksb tests...
 106  0
         GlobalResourceLoader.stop();
 107  0
         }
 108  
         
 109  
         @Override
 110  
         public List<Lifecycle> loadLifecycles() throws Exception {
 111  0
                 return Collections.emptyList();
 112  
                 //override in subclasses
 113  
         }
 114  
         
 115  
         public RunMode getRunMode() {
 116  0
                 String propertyName = getModuleName().toLowerCase() + ".mode";
 117  0
                 String runMode = ConfigContext.getCurrentContextConfig().getProperty(propertyName);
 118  0
                 if (StringUtils.isBlank(runMode)) {
 119  0
                         throw new ConfigurationException("Failed to determine run mode for module '" + getModuleName() + "'.  Please be sure to set configuration parameter '" + propertyName + "'");
 120  
                 }
 121  0
                 return RunMode.valueOf(runMode.toUpperCase());
 122  
         }
 123  
         
 124  
         public String getWebModuleConfigName() {
 125  0
                 return "config/" + getModuleName().toLowerCase();
 126  
         }
 127  
         
 128  
         public String getWebModuleConfigurationFiles() {
 129  0
                 return ConfigContext.getCurrentContextConfig().getProperty("rice." + getModuleName().toLowerCase() + ".struts.config.files");
 130  
         }
 131  
         
 132  
         /**
 133  
          * This base implementation returns true when the module has a web interface and the
 134  
          * runMode is "local".
 135  
          * 
 136  
          * Subclasses can override this method if there are different requirements for inclusion
 137  
          * of the web UI for the module.
 138  
          */
 139  
         public boolean shouldRenderWebInterface() {
 140  0
                 return hasWebInterface() &&        getRunMode().equals( RunMode.LOCAL );
 141  
         }
 142  
         
 143  
         public boolean isSetSOAPServicesAsDefault() {
 144  0
                 return Boolean.valueOf(ConfigContext.getCurrentContextConfig().getProperty("rice." + getModuleName().toLowerCase() + ".set.soap.services.as.default")).booleanValue();
 145  
         }
 146  
         
 147  
         public boolean isExposeServicesOnBus() {
 148  0
                 return Boolean.valueOf(ConfigContext.getCurrentContextConfig().getProperty("rice." + getModuleName().toLowerCase() + ".expose.services.on.bus")).booleanValue();
 149  
         }
 150  
         
 151  
         public boolean isIncludeUserInterfaceComponents() {
 152  0
                 return Boolean.valueOf(ConfigContext.getCurrentContextConfig().getProperty("rice." + getModuleName().toLowerCase() + ".include.user.interface.components")).booleanValue();
 153  
         }
 154  
 
 155  
         public String getWebModuleBaseUrl() {
 156  0
                 return ConfigContext.getCurrentContextConfig().getProperty(getModuleName().toLowerCase() + ".url");
 157  
         }
 158  
         
 159  
         @Override
 160  
         public List<String> getPrimarySpringFiles() {
 161  0
                 return Collections.singletonList(getDefaultSpringBeansPath(getDefaultConfigPackagePath()));
 162  
         }
 163  
 
 164  
         public boolean hasWebInterface() {
 165  0
                 return this.hasWebInterface;
 166  
         }
 167  
 
 168  
         public void setHasWebInterface(boolean hasWebInterface) {
 169  0
                 this.hasWebInterface = hasWebInterface;
 170  0
         }
 171  
         
 172  
         public Properties getProperties() {
 173  0
                 return this.properties;
 174  
         }
 175  
 
 176  
         public void setProperties(Properties properties) {
 177  0
                 this.properties = properties;
 178  0
         }
 179  
 
 180  
         public List<String> getAdditionalSpringFiles() {
 181  0
                 final String files = ConfigContext.getCurrentContextConfig().getProperty("rice." + getModuleName() + ".additionalSpringFiles");
 182  0
                 return files == null ? Collections.<String>emptyList() : parseFileList(files);
 183  
         }
 184  
         
 185  
         private List<String> parseFileList(String files) {
 186  0
                 final List<String> parsedFiles = new ArrayList<String>();
 187  0
                 for (String file : Arrays.asList(files.split(","))) {
 188  0
                         final String trimmedFile = file.trim();
 189  0
                         if (!trimmedFile.isEmpty()) {
 190  0
                                 parsedFiles.add(trimmedFile);        
 191  
                         }
 192  0
                 }
 193  
                 
 194  0
                 return parsedFiles;
 195  
         }
 196  
         
 197  
         public String getModuleName() {
 198  0
                 return this.moduleName;
 199  
         }
 200  
 
 201  
         public void setModuleName(String moduleName) {
 202  0
                 this.moduleName = moduleName;
 203  0
         }
 204  
     
 205  
     /* helper methods for constructors */
 206  
     protected String getDefaultConfigPackagePath() {
 207  0
             return "classpath:org/kuali/rice/" + getModuleName().toLowerCase() + "/config/";
 208  
     }
 209  
     protected String getDefaultSpringBeansPath(String configPackagePath) {
 210  0
         return configPackagePath + getModuleName().toUpperCase() + "SpringBeans.xml"; 
 211  
     }
 212  
     
 213  
         public List<RunMode> getValidRunModes() {
 214  0
                 return this.validRunModes;
 215  
         }
 216  
 
 217  
         public void setValidRunModes(List<RunMode> validRunModes) {
 218  0
                 this.validRunModes = validRunModes;
 219  0
         }
 220  
         
 221  
         @Override
 222  
         public final void validateConfigurerState() {
 223  0
                 if (StringUtils.isBlank(this.moduleName)) {
 224  0
                         throw new IllegalStateException("the module name for this module has not been set");
 225  
                 }
 226  
                 
 227  0
                 if (CollectionUtils.isEmpty(this.validRunModes)) {
 228  0
                         throw new IllegalStateException("the valid run modes for this module has not been set");
 229  
                 }
 230  
                 
 231  
                 // ConfigContext must be initialized...
 232  0
                 if (!ConfigContext.isInitialized()) {
 233  0
                     throw new ConfigurationException("ConfigContext has not yet been initialized, please initialize prior to using.");
 234  
             }
 235  
                 
 236  0
                 validateRunMode();
 237  
                 
 238  0
                 doAdditonalConfigurerValidations();
 239  0
         }
 240  
         
 241  
         private void validateRunMode() {
 242  0
                 if ( !validRunModes.contains( getRunMode() ) ) {
 243  0
                         throw new IllegalArgumentException( "Invalid run mode for the " + this.getClass().getSimpleName() + ": " + getRunMode() + " - Valid Values are: " + validRunModes );
 244  
                 }
 245  0
         }
 246  
         
 247  
         protected void doAdditonalConfigurerValidations() {
 248  
                 //override in subclasses
 249  0
         }
 250  
         
 251  
         
 252  
         /**
 253  
          * This method does the following: 
 254  
          * <ol>
 255  
          *  <li>Places all module specific configurations into the root config</li>
 256  
          *  <li>Adds any additional properties passed into the config into the root config</li>
 257  
          *  <li>Adds any items a subclass wants to put into the config</li>
 258  
          * </ol>
 259  
          */
 260  
         @Override
 261  
         public final void addToConfig() {
 262  
                 
 263  0
                 if (this.properties != null) {
 264  0
                         ConfigContext.getCurrentContextConfig().putProperties(this.properties);
 265  
                 }
 266  
                 
 267  0
                 registerConfigurerWithConfig();
 268  0
                 addAdditonalToConfig();
 269  0
         }
 270  
         
 271  
         protected void addAdditonalToConfig() {
 272  
                 //override in subclasses
 273  0
         }
 274  
         
 275  
         /**
 276  
          * This is a bit of a hack.... fix me
 277  
          *
 278  
          */
 279  
         private void registerConfigurerWithConfig() {
 280  
                 @SuppressWarnings("unchecked")
 281  0
                 Collection<ModuleConfigurer> configurers = (Collection<ModuleConfigurer>) ConfigContext.getCurrentContextConfig().getObject("ModuleConfigurers");
 282  0
                 if (configurers == null) {
 283  0
                         configurers = new ArrayList<ModuleConfigurer>();
 284  
                 }
 285  0
                 configurers.add(this);
 286  
                 
 287  0
                 ConfigContext.getCurrentContextConfig().putObject("ModuleConfigurers", configurers);
 288  0
         }
 289  
         
 290  
         @Override
 291  
         public final void initializeResourceLoaders() throws Exception {
 292  0
                 List<String> files = new ArrayList<String>();
 293  0
                 files.addAll(getPrimarySpringFiles());
 294  0
                 files.addAll(getAdditionalSpringFiles());
 295  
                 
 296  0
                 ResourceLoader rootResourceLoader = GlobalResourceLoader.getResourceLoader();
 297  0
                 if (rootResourceLoader == null) {
 298  0
                         rootResourceLoader = createRootResourceLoader();
 299  
                 }
 300  
                 
 301  0
                 if (!files.isEmpty()) {
 302  0
                         ResourceLoader rl = RiceResourceLoaderFactory.createRootRiceResourceLoader(servletContext, files, getModuleName());
 303  0
                         rl.start();
 304  0
                         GlobalResourceLoader.addResourceLoader(rl);
 305  
                 }
 306  
                 
 307  0
                 final Collection<ResourceLoader> rls = getResourceLoadersToRegister();
 308  
                 
 309  0
                 for (ResourceLoader rl : rls) {
 310  0
                         GlobalResourceLoader.addResourceLoader(rl);
 311  
                 }
 312  0
         }
 313  
         
 314  
         protected Collection<ResourceLoader> getResourceLoadersToRegister() throws Exception {
 315  0
                 return Collections.emptyList();
 316  
                 //override in subclasses
 317  
         }
 318  
         
 319  
         private ResourceLoader createRootResourceLoader() throws Exception {
 320  0
                 final ResourceLoaderContainer container = new ResourceLoaderContainer(new QName(CoreConfigHelper.getApplicationId(), RiceConstants.ROOT_RESOURCE_LOADER_CONTAINER_NAME));
 321  0
                 ResourceLoader rootResourceLoader = new BaseResourceLoader(new QName(CoreConfigHelper.getApplicationId(), RiceConstants.DEFAULT_ROOT_RESOURCE_LOADER_NAME));
 322  
                 
 323  0
                 container.addResourceLoader(rootResourceLoader);
 324  0
                 GlobalResourceLoader.addResourceLoader(container);
 325  0
                 GlobalResourceLoader.start();
 326  
                 
 327  0
                 return container;
 328  
         }
 329  
 
 330  
         @Override
 331  
         public final void onApplicationEvent(ApplicationEvent event) {
 332  0
                 if (event instanceof ContextRefreshedEvent) {
 333  0
                         doContextStartedLogic();
 334  0
                 } else if (event instanceof ContextClosedEvent) {
 335  0
                         doContextStoppedLogic();
 336  
                 }
 337  0
         }
 338  
 
 339  
         @Override
 340  
         public final void doContextStartedLogic() {
 341  0
                 doAdditionalContextStartedLogic();
 342  0
         }
 343  
 
 344  
         @Override
 345  
         public final void doContextStoppedLogic() {
 346  0
                 doAdditionalContextStoppedLogic();
 347  0
         }
 348  
         
 349  
         protected void doAdditionalContextStartedLogic() {
 350  
                 //override in subclasses
 351  0
         }
 352  
 
 353  
         protected void doAdditionalContextStoppedLogic() {
 354  
                 //override in subclasses
 355  0
         }
 356  
         
 357  
         @Override
 358  
         public void setServletContext(ServletContext servletContext) {
 359  0
                 this.servletContext = servletContext;
 360  0
         }
 361  
 }