[jboss-cvs] JBossAS SVN: r99911 - projects/security/picketbox/fresh/security-jboss-sx/jbosssx/src/main/java/org/jboss/security/config.

jboss-cvs-commits at lists.jboss.org jboss-cvs-commits at lists.jboss.org
Mon Jan 25 13:07:09 EST 2010


Author: anil.saldhana at jboss.com
Date: 2010-01-25 13:07:09 -0500 (Mon, 25 Jan 2010)
New Revision: 99911

Added:
   projects/security/picketbox/fresh/security-jboss-sx/jbosssx/src/main/java/org/jboss/security/config/StandaloneConfiguration.java
Log:
add a standalone JAAS config

Added: projects/security/picketbox/fresh/security-jboss-sx/jbosssx/src/main/java/org/jboss/security/config/StandaloneConfiguration.java
===================================================================
--- projects/security/picketbox/fresh/security-jboss-sx/jbosssx/src/main/java/org/jboss/security/config/StandaloneConfiguration.java	                        (rev 0)
+++ projects/security/picketbox/fresh/security-jboss-sx/jbosssx/src/main/java/org/jboss/security/config/StandaloneConfiguration.java	2010-01-25 18:07:09 UTC (rev 99911)
@@ -0,0 +1,154 @@
+/*
+ * JBoss, Home of Professional Open Source.
+ * Copyright 2008, Red Hat Middleware LLC, and individual contributors
+ * as indicated by the @author tags. See the copyright.txt file in the
+ * distribution for a full listing of individual contributors. 
+ *
+ * This is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU Lesser General Public License as
+ * published by the Free Software Foundation; either version 2.1 of
+ * the License, or (at your option) any later version.
+ *
+ * This software is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this software; if not, write to the Free
+ * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
+ * 02110-1301 USA, or see the FSF site: http://www.fsf.org.
+ */
+package org.jboss.security.config;
+
+import java.security.AccessController;
+import java.security.PrivilegedAction;
+import java.util.concurrent.ConcurrentHashMap;
+import java.util.concurrent.ConcurrentMap;
+
+import javax.security.auth.login.AppConfigurationEntry;
+import javax.security.auth.login.Configuration;
+
+import org.jboss.logging.Logger;
+import org.jboss.security.SecurityConstants;
+import org.jboss.security.auth.login.AuthenticationInfo;
+import org.jboss.security.auth.login.BaseAuthenticationInfo;
+
+/**
+ * JAAS {@code Configuration} extended with {@code ApplicationPolicy} registration
+ * To instantiate, use the {@link #getInstance()} method as this class acts
+ * as a singleton 
+ * @author Anil.Saldhana at redhat.com
+ * @since Jan 24, 2010
+ */
+public class StandaloneConfiguration extends Configuration implements ApplicationPolicyRegistration
+{
+   protected static Logger log = Logger.getLogger(StandaloneConfiguration.class);
+   
+   /** The inherited configuration we delegate to */
+   protected Configuration parentConfig;
+   
+   protected ConcurrentMap<String,ApplicationPolicy> appPolicyMap = new ConcurrentHashMap<String, ApplicationPolicy>();
+   
+   /**
+    * Singleton instance
+    */
+   protected static StandaloneConfiguration _instance;
+   
+   protected StandaloneConfiguration()
+   {   
+   }
+   
+   public static StandaloneConfiguration getInstance()
+   {
+     if(_instance == null)
+        _instance = new StandaloneConfiguration();
+     return _instance;
+   }
+   
+   /**
+    * @see {@code ApplicationPolicyRegistration#addApplicationPolicy(String, ApplicationPolicy)}
+    */
+   public void addApplicationPolicy(String appName, ApplicationPolicy aPolicy)
+   {
+      appPolicyMap.put(appName, aPolicy);
+      SecurityConfiguration.addApplicationPolicy(aPolicy);
+   }
+
+   /**
+    * @see {@code ApplicationPolicyRegistration#getApplicationPolicy(String)}
+    */
+   public ApplicationPolicy getApplicationPolicy(String domainName)
+   {
+      return appPolicyMap.get(domainName);
+   }
+
+   /**
+    * @see {@code ApplicationPolicyRegistration#removeApplicationPolicy(String)}
+    */
+   public boolean removeApplicationPolicy(String domainName)
+   {
+      ApplicationPolicy ap = appPolicyMap.remove(domainName);
+      return ap != null;
+   }
+   
+   /**
+    * Set the Parent Configuration to which we can delegate
+    * @param parentConfig
+    */
+   public void setParentConfig(Configuration parentConfig)
+   {
+      this.parentConfig = parentConfig;
+   }
+
+   @Override
+   public AppConfigurationEntry[] getAppConfigurationEntry(String appName)
+   {
+      AppConfigurationEntry[] entry = null;
+      
+      ApplicationPolicy aPolicy = getApplicationPolicy(appName);
+      BaseAuthenticationInfo authInfo = null;
+      if (aPolicy != null)
+         authInfo = aPolicy.getAuthenticationInfo();
+
+      if (authInfo == null)
+      {
+         if (log.isTraceEnabled())
+            log.trace("getAppConfigurationEntry(" + appName + "), no entry in appConfigs, tyring parentCont: "
+                  + parentConfig);
+         if (parentConfig != null)
+            entry = parentConfig.getAppConfigurationEntry(appName);
+         if (entry == null)
+         {
+            if (log.isTraceEnabled())
+               log.trace("getAppConfigurationEntry(" + appName + "), no entry in parentConfig, trying: "
+                     + SecurityConstants.DEFAULT_APPLICATION_POLICY);
+         }
+         ApplicationPolicy defPolicy = getApplicationPolicy(SecurityConstants.DEFAULT_APPLICATION_POLICY);
+         authInfo = defPolicy != null ? (AuthenticationInfo) defPolicy.getAuthenticationInfo() : null;
+      }
+
+      if (authInfo != null)
+      {
+         if (log.isTraceEnabled())
+            log.trace("End getAppConfigurationEntry(" + appName + "), authInfo=" + authInfo);
+         // Make a copy of the authInfo object
+         final BaseAuthenticationInfo theAuthInfo = authInfo;
+         PrivilegedAction<AppConfigurationEntry[]> action = new PrivilegedAction<AppConfigurationEntry[]>()
+         {
+            public AppConfigurationEntry[] run()
+            {
+               return theAuthInfo.copyAppConfigurationEntry();
+            }
+         };
+         entry = AccessController.doPrivileged(action);
+      }
+      else
+      {
+         if (log.isTraceEnabled())
+            log.trace("End getAppConfigurationEntry(" + appName + "), failed to find entry");
+      }
+
+      return entry; 
+   }
+}
\ No newline at end of file




More information about the jboss-cvs-commits mailing list