All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jboss.security.config.parser.ApplicationPolicyParser Maven / Gradle / Ivy

There is a newer version: 5.1.0.Final
Show newest version
/*
 * 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.parser;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List;
import java.util.Set;

import javax.security.auth.login.AppConfigurationEntry;
import javax.xml.namespace.QName;
import javax.xml.stream.XMLEventReader;
import javax.xml.stream.XMLStreamConstants;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader;
import javax.xml.stream.events.Attribute;
import javax.xml.stream.events.StartElement;
import javax.xml.stream.events.XMLEvent;

import org.jboss.security.acl.config.ACLProviderEntry;
import org.jboss.security.audit.config.AuditProviderEntry;
import org.jboss.security.auth.login.AuthenticationInfo;
import org.jboss.security.auth.login.JASPIAuthenticationInfo;
import org.jboss.security.authorization.config.AuthorizationModuleEntry;
import org.jboss.security.config.ACLInfo;
import org.jboss.security.config.ApplicationPolicy;
import org.jboss.security.config.AuditInfo;
import org.jboss.security.config.AuthorizationInfo;
import org.jboss.security.config.Element;
import org.jboss.security.config.IdentityTrustInfo;
import org.jboss.security.config.MappingInfo;
import org.jboss.security.identitytrust.config.IdentityTrustModuleEntry;
import org.jboss.security.mapping.MappingType;
import org.jboss.security.mapping.config.MappingModuleEntry;

/**
 * Stax based Application Policy Parser
 * 
 * @author [email protected]
 * @author Marcus Moyses
 * @since Jan 22, 2010
 */
public class ApplicationPolicyParser implements XMLStreamConstants
{ 
   @SuppressWarnings("unchecked")
   public List parse(XMLEventReader xmlEventReader) throws XMLStreamException
   {
      List policies = new ArrayList();
      while(xmlEventReader.hasNext())
      { 
          XMLEvent xmlEvent = xmlEventReader.nextEvent();
          int eventType = xmlEvent.getEventType();
          switch(eventType)
          {
              case XMLStreamConstants.START_ELEMENT:  
                 StartElement appPolicyElement = (StartElement) xmlEvent;
                 if("application-policy".equals(StaxParserUtil.getStartElementName(appPolicyElement)) == false)
                    throw new RuntimeException(" element expected at " + 
                          StaxParserUtil.getLineColumnNumber(xmlEvent.getLocation()));
                 //We got the application-policy element. It just has one attribute "name"
                 Iterator attrs = appPolicyElement.getAttributes(); 
                 String extendsName = null;
                 String appPolicyName = null;
                 
                 while(attrs.hasNext())
                 {
                    Attribute attribute = attrs.next();
                    QName attributeName = attribute.getName();
                    String attributeValue = StaxParserUtil.getAttributeValue(attribute);
                    
                    if("name".equals(attributeName.getLocalPart()))
                       appPolicyName = attributeValue; 
                    else if("extends".equals(attributeName.getLocalPart()))
                       extendsName = attributeValue;  
                 }

                 ApplicationPolicy applicationPolicy = new ApplicationPolicy(appPolicyName); 
                 if(extendsName != null)
                    applicationPolicy.setBaseApplicationPolicyName(extendsName);
                  
                 route(xmlEventReader, applicationPolicy);
                 policies.add(applicationPolicy); 
          } 
      }
      return policies;
   }
   
   @SuppressWarnings("unchecked")
   private void route(XMLEventReader xmlEventReader, ApplicationPolicy appPolicy) throws XMLStreamException
   {
      while(true)
      {
         XMLEvent xmlEvent = xmlEventReader.peek();
         if(xmlEvent == null)
            return;
         StartElement startElement = xmlEvent.asStartElement();
         String elementName = StaxParserUtil.getStartElementName(startElement);
         if("authentication".equals(elementName))
         {
            xmlEvent = xmlEventReader.nextEvent();
            AuthenticationConfigParser parser = new AuthenticationConfigParser();
            Set entries = parser.parse(xmlEventReader);
            AuthenticationInfo authInfo = new AuthenticationInfo();
             
            authInfo.setAppConfigurationEntry(new ArrayList(entries));
            appPolicy.setAuthenticationInfo(authInfo); 
         }
         else if("authentication-jaspi".equals(elementName))
         {

            xmlEvent = xmlEventReader.nextEvent();
            AuthenticationJASPIConfigParser parser = new AuthenticationJASPIConfigParser();
            JASPIAuthenticationInfo authInfo = parser.parse(xmlEventReader); 
            appPolicy.setAuthenticationInfo(authInfo); 
         } 
         else if("authorization".equals(elementName))
         { 
            xmlEvent = xmlEventReader.nextEvent();
            AuthorizationConfigParser parser = new AuthorizationConfigParser();
            Set entries = parser.parse(xmlEventReader);
            AuthorizationInfo authInfo = new AuthorizationInfo(appPolicy.getName());
            authInfo.add(new ArrayList(entries));
            appPolicy.setAuthorizationInfo(authInfo); 
         } 
         else if("acl".equals(elementName))
         { 
            xmlEvent = xmlEventReader.nextEvent();
            AclConfigParser parser = new AclConfigParser();
            Set entries = parser.parse(xmlEventReader);
            ACLInfo aclInfo = new ACLInfo(appPolicy.getName());
            aclInfo.add(new ArrayList(entries));
            appPolicy.setAclInfo(aclInfo); 
         }  
         else if("rolemapping".equals(elementName))
         { 
            xmlEvent = xmlEventReader.nextEvent();
            MappingConfigParser parser = new MappingConfigParser();
            List entries = parser.parse(xmlEventReader);
            MappingInfo mappingInfo = new MappingInfo(appPolicy.getName()); 
            mappingInfo.add(entries);
            appPolicy.setMappingInfo(MappingType.ROLE.toString(), mappingInfo);
         }  
         else if("mapping".equals(elementName))
         { 
            xmlEvent = xmlEventReader.nextEvent();
            MappingConfigParser parser = new MappingConfigParser();
            List entries = parser.parse(xmlEventReader);
            for(MappingModuleEntry entry: entries)
            {
               MappingInfo mappingInfo = new MappingInfo(appPolicy.getName());
               mappingInfo.add(entry);
               String moduleType = entry.getMappingModuleType();
               appPolicy.setMappingInfo(moduleType, mappingInfo); 
            }
         } 
         else if("audit".equals(elementName))
         { 
            xmlEvent = xmlEventReader.nextEvent();
            AuditConfigParser parser = new AuditConfigParser();
            List entries = parser.parse(xmlEventReader);
            AuditInfo authInfo = new AuditInfo(appPolicy.getName());
            authInfo.add(entries);
            appPolicy.setAuditInfo(authInfo); 
         } 
         else if("identity-trust".equals(elementName))
         { 
            xmlEvent = xmlEventReader.nextEvent();
            IdentityTrustConfigParser parser = new IdentityTrustConfigParser();
            List entries = parser.parse(xmlEventReader);
            IdentityTrustInfo authInfo = new IdentityTrustInfo(appPolicy.getName());
            authInfo.add(entries);
            appPolicy.setIdentityTrustInfo(authInfo); 
         } 
         else if("application-policy".equals(elementName))
            break; 
         else throw new RuntimeException("Unknown element "  + elementName + " at location " + 
               StaxParserUtil.getLineColumnNumber(xmlEvent.getLocation())); 
      }
   }
   
   public List parse(XMLStreamReader reader) throws XMLStreamException
   {
      List policies = null;
      while (reader.hasNext() && reader.nextTag() != END_ELEMENT)
      {
         final Element element = Element.forName(reader.getLocalName());
         if (element.equals(Element.APPLICATION_POLICY) || element.equals(Element.SECURITY_DOMAIN))
         {
            final int count = reader.getAttributeCount();
            if (count == 0)
               throw StaxParserUtil.missingRequired(reader, Collections.singleton(org.jboss.security.config.Attribute.NAME));
            String name = null;
            String extendsName = null;
            for (int i = 0; i < count; i++)
            {
               final String value = reader.getAttributeValue(i);
               final org.jboss.security.config.Attribute attribute = org.jboss.security.config.Attribute.forName(reader.getAttributeLocalName(i));
               switch (attribute)
               {
                  case NAME : {
                     name = value;
                     break;
                  }
                  case EXTENDS : {
                     extendsName = value;
                     break;
                  }
                  default :
                     throw StaxParserUtil.unexpectedAttribute(reader, i);
               }
            }
            if (name == null)
               throw StaxParserUtil.missingRequired(reader, Collections.singleton(org.jboss.security.config.Attribute.NAME));
            final ApplicationPolicy applicationPolicy = new ApplicationPolicy(name);
            if (extendsName != null)
               applicationPolicy.setBaseApplicationPolicyName(extendsName);
            route(reader, applicationPolicy);
            if (policies == null)
               policies = new ArrayList();
            policies.add(applicationPolicy);

         }
         else
            throw StaxParserUtil.unexpectedElement(reader);
      }
      return policies;
   }

   @SuppressWarnings("unchecked")
   private void route(XMLStreamReader reader, ApplicationPolicy appPolicy) throws XMLStreamException
   {
      while (reader.hasNext() && reader.nextTag() != END_ELEMENT)
      {
         final Element element = Element.forName(reader.getLocalName());
         switch (element)
         {
            case ACL : {
               AclConfigParser parser = new AclConfigParser();
               Set entries = parser.parse(reader);
               ACLInfo aclInfo = new ACLInfo(appPolicy.getName());
               aclInfo.add(new ArrayList(entries));
               appPolicy.setAclInfo(aclInfo);
               break;
            }
            case AUDIT : {
               AuditConfigParser parser = new AuditConfigParser();
               List entries = parser.parse(reader);
               AuditInfo authInfo = new AuditInfo(appPolicy.getName());
               authInfo.add(entries);
               appPolicy.setAuditInfo(authInfo);
               break;
            }
            case AUTHENTICATION : {
               AuthenticationConfigParser parser = new AuthenticationConfigParser();
               Set entries = parser.parse(reader);
               AuthenticationInfo authInfo = new AuthenticationInfo(appPolicy.getName());
               authInfo.setAppConfigurationEntry(new ArrayList(entries));
               appPolicy.setAuthenticationInfo(authInfo);
               break;
            }
            case AUTHENTICATION_JASPI : {
               AuthenticationJASPIConfigParser parser = new AuthenticationJASPIConfigParser();
               JASPIAuthenticationInfo authInfo = parser.parse(reader);
               appPolicy.setAuthenticationInfo(authInfo);
               break;
            }
            case AUTHORIZATION : {
               AuthorizationConfigParser parser = new AuthorizationConfigParser();
               Set entries = parser.parse(reader);
               AuthorizationInfo authInfo = new AuthorizationInfo(appPolicy.getName());
               authInfo.add(new ArrayList(entries));
               appPolicy.setAuthorizationInfo(authInfo);
               break;
            }
            case IDENTITY_TRUST : {
               IdentityTrustConfigParser parser = new IdentityTrustConfigParser();
               List entries = parser.parse(reader);
               IdentityTrustInfo authInfo = new IdentityTrustInfo(appPolicy.getName());
               authInfo.add(entries);
               appPolicy.setIdentityTrustInfo(authInfo);
               break;
            }
            case MAPPING : {
               MappingConfigParser parser = new MappingConfigParser();
               List entries = parser.parse(reader);
               for (MappingModuleEntry entry : entries)
               {
                  MappingInfo mappingInfo = new MappingInfo(appPolicy.getName());
                  mappingInfo.add(entry);
                  String moduleType = entry.getMappingModuleType();
                  appPolicy.setMappingInfo(moduleType, mappingInfo);
               }
               break;
            }
            case ROLE_MAPPING : {
               MappingConfigParser parser = new MappingConfigParser();
               List entries = parser.parse(reader);
               MappingInfo mappingInfo = new MappingInfo(appPolicy.getName());
               mappingInfo.add(entries);
               appPolicy.setMappingInfo(MappingType.ROLE.toString(), mappingInfo);
               break;
            }
            default :
               throw StaxParserUtil.unexpectedElement(reader);
         }
      }
   }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy