/** * WS-Attacker - A Modular Web Services Penetration Testing Framework Copyright * (C) 2013 Christian Mainka * * This program is free software; you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation; either version 2 of the License, or (at your option) any later * version. * * This program 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 General Public License for more * details. * * You should have received a copy of the GNU General Public License along with * this program; if not, write to the Free Software Foundation, Inc., 51 * Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ package wsattacker.library.xmlutilities.namespace; import java.util.*; import javax.xml.namespace.NamespaceContext; import org.w3c.dom.Attr; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NamedNodeMap; import org.w3c.dom.Node; import org.w3c.dom.NodeList; /** * This class is able to read in all prefix/namespace URI pairs and resolve user requests */ public class NamespaceResolver implements NamespaceContext { Map<String, String> prefixUriMap; Map<String, TreeSet<String>> uriPrefixMap; String defaultNamespace = ""; /** * Constructor with Document Object * * @param doc */ public NamespaceResolver( Document doc ) { prefixUriMap = new HashMap<String, String>(); uriPrefixMap = new HashMap<String, TreeSet<String>>(); allNamespaces( doc.getDocumentElement() ); // System.out.println("Prefix-Uri Map:\n" + prefixUriMap.toString()); // System.out.println("Uri-Prefix Map:\n" + uriPrefixMap); } /** * Reads all namespaces * * @param ele * @param nsList */ private void allNamespaces( Element ele ) { NamedNodeMap attributes = ele.getAttributes(); for ( int i = 0; i < attributes.getLength(); ++i ) { Attr attribute = (Attr) attributes.item( i ); if ( attribute.getPrefix() != null && attribute.getNamespaceURI() != null ) { String prefix = attribute.getPrefix(); String uri = attribute.getNamespaceURI(); prefixUriMap.put( prefix, uri ); if ( !uriPrefixMap.containsKey( uri ) ) { uriPrefixMap.put( uri, new TreeSet<String>() ); } uriPrefixMap.get( uri ).add( prefix ); } } String prefix = ele.getPrefix(); String uri = ele.getNamespaceURI(); if ( prefix != null && uri != null ) { prefixUriMap.put( prefix, uri ); if ( !uriPrefixMap.containsKey( uri ) ) { uriPrefixMap.put( uri, new TreeSet<String>() ); } uriPrefixMap.get( uri ).add( prefix ); } NodeList children = ele.getChildNodes(); for ( int i = 0; i < children.getLength(); ++i ) { if ( children.item( i ).getNodeType() == Node.ELEMENT_NODE ) { allNamespaces( (Element) children.item( i ) ); } } } /** * Returns the namespace URI for a given prefix */ @Override public String getNamespaceURI( String prefix ) { if ( prefix == null ) { return defaultNamespace; } return prefixUriMap.get( prefix ); } /** * Adds a prefix/namespace URI pair to the known list * * @param prefix * @param uri */ public void addNamespace( String prefix, String uri ) { prefixUriMap.put( prefix, uri ); } @Override public String getPrefix( String namespaceURI ) { return uriPrefixMap.get( namespaceURI ).first(); } @Override public Iterator<String> getPrefixes( String namespaceURI ) { return uriPrefixMap.get( namespaceURI ).iterator(); } public Map<String, String> getPrefixUriMap() { return prefixUriMap; } // public Map<String, List<String>> getUriPrefixMap() // { // return uriPrefixMap; // } }