Author: andygumbrecht
Date: Tue Dec  4 11:02:55 2012
New Revision: 1416880

URL: http://svn.apache.org/viewvc?rev=1416880&view=rev
Log:
Fix - OpenEJB 'lib' is not an AppModule and do not fail on unknown module type.
Fix - Only fail security on bad deployment.

Modified:
    
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/ConfigurationFactory.java
    
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/DeploymentLoader.java

Modified: 
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/ConfigurationFactory.java
URL: 
http://svn.apache.org/viewvc/openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/ConfigurationFactory.java?rev=1416880&r1=1416879&r2=1416880&view=diff
==============================================================================
--- 
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/ConfigurationFactory.java
 (original)
+++ 
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/ConfigurationFactory.java
 Tue Dec  4 11:02:55 2012
@@ -16,56 +16,10 @@
  */
 package org.apache.openejb.config;
 
-import java.io.File;
-import java.io.IOException;
-import java.io.InputStream;
-import java.net.MalformedURLException;
-import java.net.URI;
-import java.net.URISyntaxException;
-import java.net.URL;
-import java.net.URLClassLoader;
-import java.util.ArrayList;
-import java.util.Arrays;
-import java.util.Collection;
-import java.util.Collections;
-import java.util.Comparator;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
-import java.util.Properties;
-import java.util.Set;
-import javax.ejb.embeddable.EJBContainer;
 import org.apache.openejb.OpenEJBException;
 import org.apache.openejb.Vendor;
 import org.apache.openejb.api.Proxy;
-import org.apache.openejb.assembler.classic.AppInfo;
-import org.apache.openejb.assembler.classic.Assembler;
-import org.apache.openejb.assembler.classic.BmpEntityContainerInfo;
-import org.apache.openejb.assembler.classic.ClientInfo;
-import org.apache.openejb.assembler.classic.CmpEntityContainerInfo;
-import org.apache.openejb.assembler.classic.ConnectionManagerInfo;
-import org.apache.openejb.assembler.classic.ConnectorInfo;
-import org.apache.openejb.assembler.classic.ContainerInfo;
-import org.apache.openejb.assembler.classic.ContainerSystemInfo;
-import org.apache.openejb.assembler.classic.DeploymentExceptionManager;
-import org.apache.openejb.assembler.classic.EjbJarInfo;
-import org.apache.openejb.assembler.classic.FacilitiesInfo;
-import org.apache.openejb.assembler.classic.HandlerChainInfo;
-import org.apache.openejb.assembler.classic.HandlerInfo;
-import org.apache.openejb.assembler.classic.JndiContextInfo;
-import org.apache.openejb.assembler.classic.ManagedContainerInfo;
-import org.apache.openejb.assembler.classic.MdbContainerInfo;
-import org.apache.openejb.assembler.classic.OpenEjbConfiguration;
-import org.apache.openejb.assembler.classic.OpenEjbConfigurationFactory;
-import org.apache.openejb.assembler.classic.ProxyFactoryInfo;
-import org.apache.openejb.assembler.classic.ResourceInfo;
-import org.apache.openejb.assembler.classic.SecurityServiceInfo;
-import org.apache.openejb.assembler.classic.ServiceInfo;
-import org.apache.openejb.assembler.classic.SingletonSessionContainerInfo;
-import org.apache.openejb.assembler.classic.StatefulSessionContainerInfo;
-import org.apache.openejb.assembler.classic.StatelessSessionContainerInfo;
-import org.apache.openejb.assembler.classic.TransactionServiceInfo;
-import org.apache.openejb.assembler.classic.WebAppInfo;
+import org.apache.openejb.assembler.classic.*;
 import org.apache.openejb.component.ClassLoaderEnricher;
 import org.apache.openejb.config.sys.AbstractService;
 import org.apache.openejb.config.sys.AdditionalDeployments;
@@ -109,6 +63,25 @@ import org.apache.openejb.util.proxy.Que
 import org.apache.xbean.finder.MetaAnnotatedClass;
 import org.apache.xbean.finder.ResourceFinder;
 
+import javax.ejb.embeddable.EJBContainer;
+import java.io.File;
+import java.io.InputStream;
+import java.net.MalformedURLException;
+import java.net.URI;
+import java.net.URISyntaxException;
+import java.net.URL;
+import java.net.URLClassLoader;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.Collection;
+import java.util.Collections;
+import java.util.Comparator;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.Properties;
+import java.util.Set;
+
 import static 
org.apache.openejb.config.DeploymentsResolver.DEPLOYMENTS_CLASSPATH_PROPERTY;
 import static org.apache.openejb.config.ServiceUtils.implies;
 
@@ -556,7 +529,8 @@ public class ConfigurationFactory implem
                     IO.close(fis);
                 }
             }
-        } catch (IOException e) {
+        } catch (Exception e) {
+            logger.info("No additional deployments found: " + e);
         }
 
         // resolve jar locations //////////////////////////////////////  BEGIN 
 ///////
@@ -566,12 +540,14 @@ public class ConfigurationFactory implem
         final List<Deployments> autoDeploy = new ArrayList<Deployments>();
 
         final List<File> declaredAppsUrls = new ArrayList<File>();
-        try {
-            for (final Deployments deployment : deployments) {
+
+        for (final Deployments deployment : deployments) {
+            try {
                 DeploymentsResolver.loadFrom(deployment, base, 
declaredAppsUrls);
                 if (deployment.isAutoDeploy()) autoDeploy.add(deployment);
+            } catch (SecurityException se) {
+                logger.warning("Security check failed on deployment: " + 
deployment.getFile(), se);
             }
-        } catch (SecurityException ignored) {
         }
 
         if (autoDeploy.size() > 0) {
@@ -604,8 +580,7 @@ public class ConfigurationFactory implem
             throw new 
OpenEJBException(messages.format("unrecognizedContainerType", 
container.getType()));
         }
 
-        final ContainerInfo info = configureService(container, infoClass);
-        return info;
+        return configureService(container, infoClass);
     }
 
     private void loadPropertiesDeclaredConfiguration(final Openejb openejb) {
@@ -640,8 +615,7 @@ public class ConfigurationFactory implem
 
         final URI uri = new URI(value);
 
-        final Object service = toConfigDeclaration(name, uri);
-        return service;
+        return toConfigDeclaration(name, uri);
     }
 
     public Object toConfigDeclaration(final String id, final URI uri) throws 
OpenEJBException {
@@ -1089,8 +1063,7 @@ public class ConfigurationFactory implem
     }
 
     private <T extends ServiceInfo> void specialProcessing(final T info) {
-        final ServiceInfo serviceInfo = info;
-        TopicOrQueueDefaults.process(serviceInfo);
+        TopicOrQueueDefaults.process(info);
     }
 
 

Modified: 
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/DeploymentLoader.java
URL: 
http://svn.apache.org/viewvc/openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/DeploymentLoader.java?rev=1416880&r1=1416879&r2=1416880&view=diff
==============================================================================
--- 
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/DeploymentLoader.java
 (original)
+++ 
openejb/trunk/openejb/container/openejb-core/src/main/java/org/apache/openejb/config/DeploymentLoader.java
 Tue Dec  4 11:02:55 2012
@@ -339,7 +339,11 @@ public class DeploymentLoader implements
                             webModules.put(entry.getKey(), entry.getValue());
                         }
                     } catch (UnsupportedOperationException e) {
-                        // Ignore it as per the javaee spec EE.8.4.2 section 
1.d.iiilogger.info("Ignoring unknown module type: "+entry.getKey());
+                        // Ignore it as per the javaee spec EE.8.4.2 section 
1.d.iii
+                        logger.info("Ignoring unknown module type: " + 
entry.getKey());
+                    } catch (UnknownModuleTypeException e) {
+                        // Ignore it as per the javaee spec EE.8.4.2 section 
1.d.iii
+                        logger.info("Ignoring unknown module type: " + 
entry.getKey());
                     } catch (Exception e) {
                         throw new OpenEJBException("Unable to determine the 
module type of " + entry.getKey() + ": Exception: " + e.getMessage(), e);
                     }
@@ -1479,7 +1483,7 @@ public class DeploymentLoader implements
         }
 
         final File file = URLs.toFile(baseUrl);
-        if (file.isDirectory()) {
+        if (file.isDirectory() && 
!file.equals(SystemInstance.get().getHome().getDirectory("lib", false))) {
             if (containsEarAssets(file)) return AppModule.class;
             if (containsWebAssets(file)) return WebModule.class;
         }


Reply via email to