| // Copyright 2014 The Chromium OS Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #include <chromeos/http/http_connection_fake.h> |
| |
| #include <base/bind.h> |
| #include <base/logging.h> |
| #include <chromeos/http/http_request.h> |
| #include <chromeos/mime_utils.h> |
| #include <chromeos/streams/memory_stream.h> |
| #include <chromeos/strings/string_utils.h> |
| |
| namespace chromeos { |
| namespace http { |
| namespace fake { |
| |
| Connection::Connection(const std::string& url, |
| const std::string& method, |
| const std::shared_ptr<http::Transport>& transport) |
| : http::Connection(transport), request_(url, method) { |
| VLOG(1) << "fake::Connection created: " << method; |
| } |
| |
| Connection::~Connection() { |
| VLOG(1) << "fake::Connection destroyed"; |
| } |
| |
| bool Connection::SendHeaders(const HeaderList& headers, |
| chromeos::ErrorPtr* error) { |
| request_.AddHeaders(headers); |
| return true; |
| } |
| |
| bool Connection::SetRequestData(StreamPtr stream, chromeos::ErrorPtr* error) { |
| request_.SetData(std::move(stream)); |
| return true; |
| } |
| |
| bool Connection::FinishRequest(chromeos::ErrorPtr* error) { |
| using chromeos::string_utils::ToString; |
| request_.AddHeaders( |
| {{request_header::kContentLength, ToString(request_.GetData().size())}}); |
| fake::Transport* transport = static_cast<fake::Transport*>(transport_.get()); |
| CHECK(transport) << "Expecting a fake transport"; |
| auto handler = transport->GetHandler(request_.GetURL(), request_.GetMethod()); |
| if (handler.is_null()) { |
| LOG(ERROR) << "Received unexpected " << request_.GetMethod() |
| << " request at " << request_.GetURL(); |
| response_.ReplyText(status_code::NotFound, |
| "<html><body>Not found</body></html>", |
| chromeos::mime::text::kHtml); |
| } else { |
| handler.Run(request_, &response_); |
| } |
| return true; |
| } |
| |
| RequestID Connection::FinishRequestAsync( |
| const SuccessCallback& success_callback, |
| const ErrorCallback& error_callback) { |
| transport_->RunCallbackAsync(FROM_HERE, |
| base::Bind(&Connection::FinishRequestAsyncHelper, |
| base::Unretained(this), |
| success_callback, |
| error_callback)); |
| return 1; |
| } |
| |
| void Connection::FinishRequestAsyncHelper( |
| const SuccessCallback& success_callback, |
| const ErrorCallback& error_callback) { |
| chromeos::ErrorPtr error; |
| if (!FinishRequest(&error)) { |
| error_callback.Run(1, error.get()); |
| } else { |
| scoped_ptr<Response> response{new Response{shared_from_this()}}; |
| success_callback.Run(1, response.Pass()); |
| } |
| } |
| |
| int Connection::GetResponseStatusCode() const { |
| return response_.GetStatusCode(); |
| } |
| |
| std::string Connection::GetResponseStatusText() const { |
| return response_.GetStatusText(); |
| } |
| |
| std::string Connection::GetProtocolVersion() const { |
| return response_.GetProtocolVersion(); |
| } |
| |
| std::string Connection::GetResponseHeader( |
| const std::string& header_name) const { |
| return response_.GetHeader(header_name); |
| } |
| |
| StreamPtr Connection::ExtractDataStream(chromeos::ErrorPtr* error) { |
| // HEAD requests must not return body. |
| if (request_.GetMethod() != request_type::kHead) { |
| return MemoryStream::OpenRef(response_.GetData(), error); |
| } else { |
| // Return empty data stream for HEAD requests. |
| return MemoryStream::OpenCopyOf(nullptr, 0, error); |
| } |
| } |
| |
| } // namespace fake |
| } // namespace http |
| } // namespace chromeos |