10 #ifndef __PION_HTTP_RESPONSE_READER_HEADER__ 11 #define __PION_HTTP_RESPONSE_READER_HEADER__ 13 #include <boost/asio.hpp> 14 #include <boost/bind.hpp> 15 #include <boost/function.hpp> 16 #include <boost/function/function2.hpp> 17 #include <boost/shared_ptr.hpp> 18 #include <boost/enable_shared_from_this.hpp> 19 #include <pion/config.hpp> 20 #include <pion/http/response.hpp> 21 #include <pion/http/reader.hpp> 33 public boost::enable_shared_from_this<response_reader>
39 typedef boost::function3<void, http::response_ptr, tcp::connection_ptr,
53 static inline boost::shared_ptr<response_reader>
55 finished_handler_t handler)
57 return boost::shared_ptr<response_reader>
75 finished_handler_t handler)
79 m_http_msg->set_remote_ip(tcp_conn->get_remote_ip());
80 set_logger(PION_GET_LOGGER(
"pion.http.response_reader"));
87 boost::asio::placeholders::error,
88 boost::asio::placeholders::bytes_transferred));
119 typedef boost::shared_ptr<response_reader> response_reader_ptr;
void consume_bytes(void)
Consumes bytes that have been read using an HTTP parser.
http::response_ptr m_http_msg
The new HTTP message container being created.
response_reader(const tcp::connection_ptr &tcp_conn, const http::request &http_request, finished_handler_t handler)
tcp::connection_ptr & get_connection(void)
returns a shared pointer to the TCP connection
boost::function3< void, http::response_ptr, tcp::connection_ptr, const boost::system::error_code & > finished_handler_t
function called after the HTTP message has been parsed
virtual void read_bytes(void)
Reads more bytes from the TCP connection.
virtual void finished_parsing_headers(const boost::system::error_code &ec)
Called after we have finished parsing the HTTP message headers.
virtual http::message & get_message(void)
Returns a reference to the HTTP message being parsed.
static boost::shared_ptr< response_reader > create(const tcp::connection_ptr &tcp_conn, const http::request &http_request, finished_handler_t handler)
virtual void finished_reading(const boost::system::error_code &ec)
Called after we have finished reading/parsing the HTTP message.
void set_logger(logger log_ptr)
sets the logger to be used
finished_handler_t m_parsed_headers
function called after the HTTP message headers have been parsed
void set_headers_parsed_callback(finished_handler_t &h)
sets a function to be called after HTTP headers have been parsed
finished_handler_t m_finished
function called after the HTTP message has been parsed