/usr/include/xsec/utils/XSECSOAPRequestorSimple.hpp is in libxml-security-c-dev 1.7.2-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 | /**
* 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.
*/
/*
* XSEC
*
* XSECSOAPRequestorSimple := (Very) Basic implementation of a SOAP
* HTTP wrapper for testing the client code.
*
*
* $Id: XSECSOAPRequestorSimple.hpp 1125514 2011-05-20 19:08:33Z scantor $
*
*/
#ifndef XSECSOAPREQUESTORSIMPLE_INCLUDE
#define XSECSOAPREQUESTORSIMPLE_INCLUDE
#include <xsec/framework/XSECDefs.hpp>
#include <xsec/utils/XSECSOAPRequestor.hpp>
#include <xercesc/util/XMLUri.hpp>
XSEC_DECLARE_XERCES_CLASS(DOMDocument);
/**
* @ingroup xkms
*/
/*\@{*/
/**
* @brief Basic HTTP implementation for SOAP Requests
*
* The XKMS client code needs to be able to call on a SOAP requestor
* implementation that will handle wrapping the request in a SOAP msg
* and transporting it to the SOAP server. This class provides a very
* naieve implementation that wraps the message and does a basic
* HTTP POST to get the message to the end server.
*
*/
class DSIG_EXPORT XSECSOAPRequestorSimple : public XSECSOAPRequestor {
public :
/**
* Envelope Enumeration
*/
enum envelopeType {
ENVELOPE_NONE, /** No envelope - straight HTTP request */
ENVELOPE_SOAP11, /** SOAP 1.1 envelope (default) */
ENVELOPE_SOAP12 /** SOAP 1.2 envelope */
};
/** @name Constructors and Destructors */
//@{
/**
* \brief Constructor
*
* Create a SOAP requestor that can be used to access a specific
* server
*
* @param uri The URI of the server that will be accessed.
* @note The URI must be http://...
*/
XSECSOAPRequestorSimple(const XMLCh * uri);
virtual ~XSECSOAPRequestorSimple();
//@}
/** @name Interface methods */
//@{
/**
* \brief Do a SOAP request
*
* Performs a request based on the passed in DOM document and
* the indicated URI. The function is returns a pointer
* to the parsed result message (with the SOAP envelope removed)
*
* @param request The DOM document containing the message to be
* wrapped and sent.
* @returns The DOM document representing the result, with all
* SOAP headers removed
*/
virtual XERCES_CPP_NAMESPACE_QUALIFIER DOMDocument *
doRequest(XERCES_CPP_NAMESPACE_QUALIFIER DOMDocument * request);
//@}
/** @name Configuration methods */
//@{
/**
* \brief Set the envelope type
*
* The requestor can do a SOAP 1.1, SOAP 1.2 or no envelope around the
* message. This call allows the apllication to set the type.
*
* By default, the requestor uses a SOAP 1.1 envelope
*
* @param et - the type of envelope to use
*/
void setEnvelopeType(envelopeType et);
private:
char * wrapAndSerialise(XERCES_CPP_NAMESPACE_QUALIFIER DOMDocument * request);
XERCES_CPP_NAMESPACE_QUALIFIER DOMDocument *
parseAndUnwrap(const char * buf, unsigned int len);
XERCES_CPP_NAMESPACE_QUALIFIER XMLUri
m_uri;
envelopeType m_envelopeType;
};
#endif /* XSECSOAPREQUESTORSIMPLE_INCLUDE */
|