You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
47 lines
1.0 KiB
C++
47 lines
1.0 KiB
C++
#ifndef CSOAP_SOAP_RESPONSE_H_
|
|
#define CSOAP_SOAP_RESPONSE_H_
|
|
|
|
#include "csoap/soap_message.h"
|
|
|
|
namespace csoap {
|
|
|
|
// SOAP response.
|
|
class SoapResponse : public SoapMessage {
|
|
public:
|
|
// Could be "Price" for an operation/method like "GetXyzPrice".
|
|
// Really depend on the service.
|
|
// Most services use a general name "Result".
|
|
void set_result_name(const std::string& result_name) {
|
|
result_name_ = result_name;
|
|
}
|
|
|
|
const std::string& result() const {
|
|
return result_;
|
|
}
|
|
|
|
void set_result(const std::string& result) {
|
|
result_ = result;
|
|
}
|
|
|
|
protected:
|
|
void ToXmlBody(pugi::xml_node xbody) override;
|
|
|
|
bool FromXmlBody(pugi::xml_node xbody) override;
|
|
|
|
private:
|
|
// NOTE:
|
|
// Multiple results might be necessary. But for most cases, single result
|
|
// should be enough, because an API normally returns only one value.
|
|
|
|
// Result XML node name.
|
|
// Used to parse the response XML from client side.
|
|
std::string result_name_;
|
|
|
|
// Result value.
|
|
std::string result_;
|
|
};
|
|
|
|
} // namespace csoap
|
|
|
|
#endif // CSOAP_SOAP_RESPONSE_H_
|