#ifndef _XMLRPCSERVERCONNECTION_H_ #define _XMLRPCSERVERCONNECTION_H_ // // XmlRpc++ Copyright (c) 2002-2003 by Chris Morley // #if defined(_MSC_VER) # pragma warning(disable:4786) // identifier was truncated in debug info #endif #ifndef MAKEDEPEND # include <string> #endif #include "XmlRpcValue.h" #include "XmlRpcSource.h" namespace XmlRpc { // The server waits for client connections and provides methods class XmlRpcServer; class XmlRpcServerMethod; //! A class to handle XML RPC requests from a particular client class XmlRpcServerConnection : public XmlRpcSource { public: // Static data static const char METHODNAME_TAG[]; static const char PARAMS_TAG[]; static const char PARAMS_ETAG[]; static const char PARAM_TAG[]; static const char PARAM_ETAG[]; static const std::string SYSTEM_MULTICALL; static const std::string METHODNAME; static const std::string PARAMS; static const std::string FAULTCODE; static const std::string FAULTSTRING; //! Constructor XmlRpcServerConnection(int fd, XmlRpcServer* server, bool deleteOnClose = false); //! Destructor virtual ~XmlRpcServerConnection(); // XmlRpcSource interface implementation //! Handle IO on the client connection socket. //! @param eventType Type of IO event that occurred. @see XmlRpcDispatch::EventType. virtual unsigned handleEvent(unsigned eventType); protected: bool readHeader(); bool readRequest(); bool writeResponse(); // Parses the request, runs the method, generates the response xml. virtual void executeRequest(); // Parse the methodName and parameters from the request. std::string parseRequest(XmlRpcValue& params); // Execute a named method with the specified params. bool executeMethod(const std::string& methodName, XmlRpcValue& params, XmlRpcValue& result); // Execute multiple calls and return the results in an array. bool executeMulticall(const std::string& methodName, XmlRpcValue& params, XmlRpcValue& result); // Construct a response from the result XML. void generateResponse(std::string const& resultXml); void generateFaultResponse(std::string const& msg, int errorCode = -1); std::string generateHeader(std::string const& body); // The XmlRpc server that accepted this connection XmlRpcServer* _server; // Possible IO states for the connection enum ServerConnectionState { READ_HEADER, READ_REQUEST, WRITE_RESPONSE }; ServerConnectionState _connectionState; // Request headers std::string _header; // Number of bytes expected in the request body (parsed from header) int _contentLength; // Request body std::string _request; // Response std::string _response; // Number of bytes of the response written so far int _bytesWritten; // Whether to keep the current client connection open for further requests bool _keepAlive; }; } // namespace XmlRpc #endif // _XMLRPCSERVERCONNECTION_H_