Skip to content

Commit

Permalink
Merge pull request #117 from slepasteur/development
Browse files Browse the repository at this point in the history
Fix header reading on linux listener using HTTPS.
  • Loading branch information
ras0219-msft committed May 31, 2016
2 parents 72aaec6 + 11a53da commit 0b4359b
Show file tree
Hide file tree
Showing 2 changed files with 56 additions and 6 deletions.
11 changes: 6 additions & 5 deletions Release/src/http/listener/http_server_asio.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ using namespace boost::asio;
using namespace boost::asio::ip;

#define CRLF std::string("\r\n")
#define CRLFCRLF std::string("\r\n\r\n")

namespace web
{
Expand All @@ -57,7 +58,7 @@ namespace details
// This is used as part of the async_read_until call below; see the
// following for more details:
// http://www.boost.org/doc/libs/1_55_0/doc/html/boost_asio/reference/async_read_until/overload4.html
struct crlf_nonascii_searcher_t
struct crlfcrlf_nonascii_searcher_t
{
enum class State
{
Expand Down Expand Up @@ -144,14 +145,14 @@ struct crlf_nonascii_searcher_t
}
return std::make_pair(excluded, false);
}
} crlf_nonascii_searcher;
} crlfcrlf_nonascii_searcher;
}}}}}

namespace boost
{
namespace asio
{
template <> struct is_match_condition<web::http::experimental::listener::details::crlf_nonascii_searcher_t> : public boost::true_type {};
template <> struct is_match_condition<web::http::experimental::listener::details::crlfcrlf_nonascii_searcher_t> : public boost::true_type {};
}}

namespace web
Expand Down Expand Up @@ -205,14 +206,14 @@ void connection::start_request_response()

if (m_ssl_stream)
{
boost::asio::async_read_until(*m_ssl_stream, m_request_buf, CRLF, [this](const boost::system::error_code& ec, std::size_t)
boost::asio::async_read_until(*m_ssl_stream, m_request_buf, CRLFCRLF, [this](const boost::system::error_code& ec, std::size_t)
{
this->handle_http_line(ec);
});
}
else
{
boost::asio::async_read_until(*m_socket, m_request_buf, crlf_nonascii_searcher, [this](const boost::system::error_code& ec, std::size_t)
boost::asio::async_read_until(*m_socket, m_request_buf, crlfcrlf_nonascii_searcher, [this](const boost::system::error_code& ec, std::size_t)
{
this->handle_http_line(ec);
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -488,6 +488,42 @@ AvLsTlswO+wDLXM1DoKxzFBZL5o8927niqW+vZpzyGc1uPmC1MG7+MDKdZsR+e+9
XzJTD4slrGSJrcpLt/g/Jqqdjg==
-----END PRIVATE KEY-----
)";

auto body = utility::string_t{U("body content")};
http_headers all_headers;
all_headers.add(U("Accept"), U("text/plain"));
all_headers.add(U("Accept-Charset"), U("utf-8"));
all_headers.add(U("Accept-Encoding"), U("gzip, deflate"));
all_headers.add(U("Accept-Language"), U("en-US"));
all_headers.add(U("Accept-Datetime"), U("Thu, 31 May 2007 20:35:00 GMT"));
all_headers.add(U("Authorization"), U("Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=="));
all_headers.add(U("Cache-Control"), U("no-cache"));
all_headers.add(U("Cookie"), U("$Version=1; Skin=new;"));
all_headers.add(U("Content-Length"), body.size());
all_headers.add(U("Content-MD5"), U("Q2hlY2sgSW50ZWdyaXR5IQ=="));
all_headers.add(U("Content-Type"), U("application/x-www-form-urlencoded"));
all_headers.add(U("Date"), U("Tue, 15 Nov 1994 08:12:31 GMT"));
all_headers.add(U("Expect"), U("100-continue"));
all_headers.add(U("Forwarded"), U("for=192.0.2.60;proto=http;by=203.0.113.43Forwarded: for=192.0.2.43, for=198.51.100.17"));
all_headers.add(U("From"), U("[email protected]"));
all_headers.add(U("Host"), U("en.wikipedia.org"));
all_headers.add(U("If-Match"), U("\"737060cd8c284d8af7ad3082f209582d\""));
all_headers.add(U("If-Modified-Since"), U("Sat, 29 Oct 1994 19:43:31 GMT"));
all_headers.add(U("If-None-Match"), U("\"737060cd8c284d8af7ad3082f209582d\""));
all_headers.add(U("If-Range"), U("\"737060cd8c284d8af7ad3082f209582d\""));
all_headers.add(U("If-Unmodified-Since"), U("Sat, 29 Oct 1994 19:43:31 GMT"));
all_headers.add(U("Max-Forwards"), U("10"));
all_headers.add(U("Origin"), U("http://www.example-social-network.com"));
all_headers.add(U("Pragma"), U("no-cache"));
all_headers.add(U("Proxy-Authorization"), U("Basic QWxhZGRpbjpvcGVuIHNlc2FtZQ=="));
all_headers.add(U("Range"), U("bytes=500-999"));
all_headers.add(U("Referer"), U("http://en.wikipedia.org/wiki/Main_Page"));
all_headers.add(U("TE"), U("trailers, deflate"));
all_headers.add(U("User-Agent"), U("Mozilla/5.0 (X11; Linux x86_64; rv:12.0) Gecko/20100101 Firefox/21.0"));
all_headers.add(U("Upgrade"), U("HTTP/2.0, SHTTP/1.3, IRC/6.9, RTA/x11"));
all_headers.add(U("Via"), U("1.0 fred, 1.1 example.com (Apache/1.1)"));
all_headers.add(U("Warning"), U("199 Miscellaneous warning"));

boost::asio::const_buffer cert(self_signed_cert, std::strlen(self_signed_cert));
boost::asio::const_buffer key(private_key, std::strlen(private_key));

Expand All @@ -503,9 +539,19 @@ XzJTD4slrGSJrcpLt/g/Jqqdjg==
http_listener listener(m_secure_uri, server_config);

listener.support(methods::GET,
[](http_request request)
[&](http_request request)
{
http_asserts::assert_request_equals(request, methods::GET, U("/"));

for (auto&& h : all_headers)
{
std::cout << "HEADER - " << h.first << ": " << h.second << std::endl;
VERIFY_IS_TRUE(request.headers().has(h.first));
VERIFY_ARE_EQUAL(h.second, request.headers().find(h.first)->second);
}

VERIFY_ARE_EQUAL(body, request.extract_string(true).get());

request.reply(status_codes::OK);
});

Expand All @@ -522,6 +568,9 @@ XzJTD4slrGSJrcpLt/g/Jqqdjg==
http_request msg(methods::GET);
msg.set_request_uri(U("/"));

msg.headers() = all_headers;
msg.set_body(body);

http_asserts::assert_response_equals(client.request(msg).get(), status_codes::OK);

listener.close().wait();
Expand Down

0 comments on commit 0b4359b

Please sign in to comment.