[jboss-cvs] JBossAS SVN: r103599 - projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping.

jboss-cvs-commits at lists.jboss.org jboss-cvs-commits at lists.jboss.org
Tue Apr 6 17:53:34 EDT 2010


Author: anil.saldhana at jboss.com
Date: 2010-04-06 17:53:33 -0400 (Tue, 06 Apr 2010)
New Revision: 103599

Modified:
   projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/JBossMappingManager.java
   projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/SecurityActions.java
Log:
SECURITY-500: loadClass bottleneck

Modified: projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/JBossMappingManager.java
===================================================================
--- projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/JBossMappingManager.java	2010-04-06 21:21:56 UTC (rev 103598)
+++ projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/JBossMappingManager.java	2010-04-06 21:53:33 UTC (rev 103599)
@@ -22,13 +22,15 @@
 package org.jboss.security.plugins.mapping;
 
 import java.util.ArrayList;
+import java.util.Map;
+import java.util.WeakHashMap;
 
 import org.jboss.logging.Logger;
 import org.jboss.security.SecurityConstants;
 import org.jboss.security.SecurityContext;
 import org.jboss.security.config.ApplicationPolicy;
 import org.jboss.security.config.MappingInfo;
-import org.jboss.security.config.SecurityConfiguration;
+import org.jboss.security.config.SecurityConfiguration; 
 import org.jboss.security.mapping.MappingContext;
 import org.jboss.security.mapping.MappingManager;
 import org.jboss.security.mapping.MappingProvider;
@@ -48,6 +50,8 @@
    
    private String securityDomain;
 
+   private static Map<String, Class<?> > clazzMap = new WeakHashMap<String, Class<?>>();
+
    public JBossMappingManager(String domain)
    {
      this.securityDomain = domain;   
@@ -138,8 +142,13 @@
       try
       {
          String fqn = mme.getMappingModuleName();
-         Class<?> cl = SecurityActions.loadClass(fqn,tcl);
-         mp = (MappingProvider<T>) cl.newInstance();
+         Class<?> clazz = clazzMap.get(fqn);
+         if( clazz == null )
+         {
+            clazz = tcl.loadClass(fqn);
+            clazzMap.put(fqn, clazz); 
+         } 
+         mp = (MappingProvider<T>) clazz.newInstance();
          mp.init(mme.getOptions());
       }
       catch(Exception e)

Modified: projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/SecurityActions.java
===================================================================
--- projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/SecurityActions.java	2010-04-06 21:21:56 UTC (rev 103598)
+++ projects/security/security-jboss-sx/branches/Branch_2_0/jbosssx/src/main/java/org/jboss/security/plugins/mapping/SecurityActions.java	2010-04-06 21:53:33 UTC (rev 103599)
@@ -23,8 +23,6 @@
 
 import java.security.AccessController;
 import java.security.PrivilegedAction;
-import java.security.PrivilegedActionException;
-import java.security.PrivilegedExceptionAction;
  
 /**
  *  Privileged Blocks
@@ -43,17 +41,5 @@
            return Thread.currentThread().getContextClassLoader();
         }
      });
-  }
-  
-  static Class<?> loadClass(final String fqn, final ClassLoader tcl) 
-  throws PrivilegedActionException
-  {
-     return AccessController.doPrivileged(new PrivilegedExceptionAction<Class<?>>()
-     { 
-        public Class<?> run() throws PrivilegedActionException, ClassNotFoundException
-        {
-           return tcl.loadClass(fqn);
-        }
-     });   
-  }
+  } 
 }
\ No newline at end of file




More information about the jboss-cvs-commits mailing list