/* * reserved comment block * DO NOT REMOVE OR ALTER! */ /** * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ package com.sun.org.apache.xml.internal.security.transforms.params; import com.sun.org.apache.xml.internal.security.exceptions.XMLSecurityException; import com.sun.org.apache.xml.internal.security.transforms.TransformParam; import com.sun.org.apache.xml.internal.security.utils.ElementProxy; import com.sun.org.apache.xml.internal.security.utils.XMLUtils; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.Node; import org.w3c.dom.NodeList; /** * Implements the parameters for the <A * HREF="http://www.w3.org/TR/xmldsig-filter2/">XPath Filter v2.0</A>. * * @author $Author: coheigea $ * @see <A HREF="http://www.w3.org/TR/xmldsig-filter2/">XPath Filter v2.0 (TR)</A> */ public class XPath2FilterContainer04 extends ElementProxy implements TransformParam { /** Field _ATT_FILTER */ private static final String _ATT_FILTER = "Filter"; /** Field _ATT_FILTER_VALUE_INTERSECT */ private static final String _ATT_FILTER_VALUE_INTERSECT = "intersect"; /** Field _ATT_FILTER_VALUE_SUBTRACT */ private static final String _ATT_FILTER_VALUE_SUBTRACT = "subtract"; /** Field _ATT_FILTER_VALUE_UNION */ private static final String _ATT_FILTER_VALUE_UNION = "union"; /** Field _TAG_XPATH2 */ public static final String _TAG_XPATH2 = "XPath"; /** Field XPathFiler2NS */ public static final String XPathFilter2NS = "http://www.w3.org/2002/04/xmldsig-filter2"; /** * Constructor XPath2FilterContainer04 * */ private XPath2FilterContainer04() { // no instantiation } /** * Constructor XPath2FilterContainer04 * * @param doc * @param xpath2filter * @param filterType */ private XPath2FilterContainer04(Document doc, String xpath2filter, String filterType) { super(doc); this.constructionElement.setAttributeNS( null, XPath2FilterContainer04._ATT_FILTER, filterType); if ((xpath2filter.length() > 2) && (!Character.isWhitespace(xpath2filter.charAt(0)))) { XMLUtils.addReturnToElement(this.constructionElement); this.constructionElement.appendChild(doc.createTextNode(xpath2filter)); XMLUtils.addReturnToElement(this.constructionElement); } else { this.constructionElement.appendChild(doc.createTextNode(xpath2filter)); } } /** * Constructor XPath2FilterContainer04 * * @param element * @param BaseURI * @throws XMLSecurityException */ private XPath2FilterContainer04(Element element, String BaseURI) throws XMLSecurityException { super(element, BaseURI); String filterStr = this.constructionElement.getAttributeNS(null, XPath2FilterContainer04._ATT_FILTER); if (!filterStr.equals(XPath2FilterContainer04._ATT_FILTER_VALUE_INTERSECT) && !filterStr.equals(XPath2FilterContainer04._ATT_FILTER_VALUE_SUBTRACT) && !filterStr.equals(XPath2FilterContainer04._ATT_FILTER_VALUE_UNION)) { Object exArgs[] = { XPath2FilterContainer04._ATT_FILTER, filterStr, XPath2FilterContainer04._ATT_FILTER_VALUE_INTERSECT + ", " + XPath2FilterContainer04._ATT_FILTER_VALUE_SUBTRACT + " or " + XPath2FilterContainer04._ATT_FILTER_VALUE_UNION }; throw new XMLSecurityException("attributeValueIllegal", exArgs); } } /** * Creates a new XPath2FilterContainer04 with the filter type "intersect". * * @param doc * @param xpath2filter * @return the instance */ public static XPath2FilterContainer04 newInstanceIntersect( Document doc, String xpath2filter ) { return new XPath2FilterContainer04( doc, xpath2filter, XPath2FilterContainer04._ATT_FILTER_VALUE_INTERSECT); } /** * Creates a new XPath2FilterContainer04 with the filter type "subtract". * * @param doc * @param xpath2filter * @return the instance */ public static XPath2FilterContainer04 newInstanceSubtract( Document doc, String xpath2filter ) { return new XPath2FilterContainer04( doc, xpath2filter, XPath2FilterContainer04._ATT_FILTER_VALUE_SUBTRACT); } /** * Creates a new XPath2FilterContainer04 with the filter type "union". * * @param doc * @param xpath2filter * @return the instance */ public static XPath2FilterContainer04 newInstanceUnion( Document doc, String xpath2filter ) { return new XPath2FilterContainer04( doc, xpath2filter, XPath2FilterContainer04._ATT_FILTER_VALUE_UNION); } /** * Creates a XPath2FilterContainer04 from an existing Element; needed for verification. * * @param element * @param BaseURI * @return the instance * * @throws XMLSecurityException */ public static XPath2FilterContainer04 newInstance( Element element, String BaseURI ) throws XMLSecurityException { return new XPath2FilterContainer04(element, BaseURI); } /** * Returns <code>true</code> if the <code>Filter</code> attribute has value "intersect". * * @return <code>true</code> if the <code>Filter</code> attribute has value "intersect". */ public boolean isIntersect() { return this.constructionElement.getAttributeNS( null, XPath2FilterContainer04._ATT_FILTER ).equals(XPath2FilterContainer04._ATT_FILTER_VALUE_INTERSECT); } /** * Returns <code>true</code> if the <code>Filter</code> attribute has value "subtract". * * @return <code>true</code> if the <code>Filter</code> attribute has value "subtract". */ public boolean isSubtract() { return this.constructionElement.getAttributeNS( null, XPath2FilterContainer04._ATT_FILTER ).equals(XPath2FilterContainer04._ATT_FILTER_VALUE_SUBTRACT); } /** * Returns <code>true</code> if the <code>Filter</code> attribute has value "union". * * @return <code>true</code> if the <code>Filter</code> attribute has value "union". */ public boolean isUnion() { return this.constructionElement.getAttributeNS( null, XPath2FilterContainer04._ATT_FILTER ).equals(XPath2FilterContainer04._ATT_FILTER_VALUE_UNION); } /** * Returns the XPath 2 Filter String * * @return the XPath 2 Filter String */ public String getXPathFilterStr() { return this.getTextFromTextChild(); } /** * Returns the first Text node which contains information from the XPath 2 * Filter String. We must use this stupid hook to enable the here() function * to work. * * $todo$ I dunno whether this crashes: <XPath> here()<!-- comment -->/ds:Signature[1]</XPath> * @return the first Text node which contains information from the XPath 2 Filter String */ public Node getXPathFilterTextNode() { NodeList children = this.constructionElement.getChildNodes(); int length = children.getLength(); for (int i = 0; i < length; i++) { if (children.item(i).getNodeType() == Node.TEXT_NODE) { return children.item(i); } } return null; } /** @inheritDoc */ public final String getBaseLocalName() { return XPath2FilterContainer04._TAG_XPATH2; } /** @inheritDoc */ public final String getBaseNamespace() { return XPath2FilterContainer04.XPathFilter2NS; } }