/* * Copyright 2002-2005 The Apache Software Foundation. * * Licensed 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. */ /* * XSEC * * TXFMXPath := Class that performs XPath transforms * * $Id: TXFMXPath.hpp 394807 2006-04-17 23:15:38Z blautenb $ * */ #include #include #include #include #include // Xerces XSEC_DECLARE_XERCES_CLASS(DOMNode); XSEC_DECLARE_XERCES_CLASS(DOMNamedNodeMap); // Xalan #ifndef XSEC_NO_XALAN #include #include #include #include #include #include #include #include #include #include #include #endif #ifndef XSEC_NO_XPATH /** * \brief Transformer to handle XPath transforms * @ingroup internal */ class DSIG_EXPORT TXFMXPath : public TXFMBase { private: safeBuffer expr; // The expression being worked with XERCES_CPP_NAMESPACE_QUALIFIER DOMDocument * document; XERCES_CPP_NAMESPACE_QUALIFIER DOMNamedNodeMap * XPathAtts; // Attributes that came through from the doc static bool XPathInitDone; DSIGXPathHere * here; // The function to implement here() XSECSafeBufferFormatter * formatter; public: TXFMXPath(XERCES_CPP_NAMESPACE_QUALIFIER DOMDocument *doc); ~TXFMXPath(); // Methods to set the inputs void setInput(TXFMBase *newInput); // Methods to get tranform output type and input requirement virtual TXFMBase::ioType getInputType(void); virtual TXFMBase::ioType getOutputType(void); virtual TXFMBase::nodeType getNodeType(void); // XPath unique void setNameSpace(XERCES_CPP_NAMESPACE_QUALIFIER DOMNamedNodeMap *xpAtts); void evaluateExpr(XERCES_CPP_NAMESPACE_QUALIFIER DOMNode *h, safeBuffer inexpr); void evaluateEnvelope(XERCES_CPP_NAMESPACE_QUALIFIER DOMNode *t); // Methods to get output data virtual unsigned int readBytes(XMLByte * const toFill, const unsigned int maxToFill); virtual XERCES_CPP_NAMESPACE_QUALIFIER DOMDocument *getDocument(); virtual XERCES_CPP_NAMESPACE_QUALIFIER DOMNode *getFragmentNode(); virtual const XMLCh * getFragmentId(); virtual XSECXPathNodeList & getXPathNodeList(); private: TXFMXPath(); }; #endif