• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //
2 // connection.hpp
3 // ~~~~~~~~~~~~~~
4 //
5 // Copyright (c) 2003-2020 Christopher M. Kohlhoff (chris at kohlhoff dot com)
6 //
7 // Distributed under the Boost Software License, Version 1.0. (See accompanying
8 // file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
9 //
10 
11 #ifndef HTTP_SERVER3_CONNECTION_HPP
12 #define HTTP_SERVER3_CONNECTION_HPP
13 
14 #include <boost/asio.hpp>
15 #include <boost/array.hpp>
16 #include <boost/noncopyable.hpp>
17 #include <boost/shared_ptr.hpp>
18 #include <boost/enable_shared_from_this.hpp>
19 #include "reply.hpp"
20 #include "request.hpp"
21 #include "request_handler.hpp"
22 #include "request_parser.hpp"
23 
24 namespace http {
25 namespace server3 {
26 
27 /// Represents a single connection from a client.
28 class connection
29   : public boost::enable_shared_from_this<connection>,
30     private boost::noncopyable
31 {
32 public:
33   /// Construct a connection with the given io_context.
34   explicit connection(boost::asio::io_context& io_context,
35       request_handler& handler);
36 
37   /// Get the socket associated with the connection.
38   boost::asio::ip::tcp::socket& socket();
39 
40   /// Start the first asynchronous operation for the connection.
41   void start();
42 
43 private:
44   /// Handle completion of a read operation.
45   void handle_read(const boost::system::error_code& e,
46       std::size_t bytes_transferred);
47 
48   /// Handle completion of a write operation.
49   void handle_write(const boost::system::error_code& e);
50 
51   /// Strand to ensure the connection's handlers are not called concurrently.
52   boost::asio::strand<boost::asio::io_context::executor_type> strand_;
53 
54   /// Socket for the connection.
55   boost::asio::ip::tcp::socket socket_;
56 
57   /// The handler used to process the incoming request.
58   request_handler& request_handler_;
59 
60   /// Buffer for incoming data.
61   boost::array<char, 8192> buffer_;
62 
63   /// The incoming request.
64   request request_;
65 
66   /// The parser for the incoming request.
67   request_parser request_parser_;
68 
69   /// The reply to be sent back to the client.
70   reply reply_;
71 };
72 
73 typedef boost::shared_ptr<connection> connection_ptr;
74 
75 } // namespace server3
76 } // namespace http
77 
78 #endif // HTTP_SERVER3_CONNECTION_HPP
79