OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "mojo/services/network/url_loader_impl.h" | 5 #include "mojo/services/network/url_loader_impl.h" |
6 | 6 |
7 #include "base/memory/scoped_vector.h" | 7 #include "base/memory/scoped_vector.h" |
8 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
9 #include "mojo/common/common_type_converters.h" | 9 #include "mojo/common/common_type_converters.h" |
10 #include "mojo/common/url_type_converters.h" | 10 #include "mojo/common/url_type_converters.h" |
11 #include "mojo/services/network/net_adapters.h" | 11 #include "mojo/services/network/net_adapters.h" |
12 #include "mojo/services/network/network_context.h" | 12 #include "mojo/services/network/network_context.h" |
13 #include "net/base/elements_upload_data_stream.h" | 13 #include "net/base/elements_upload_data_stream.h" |
14 #include "net/base/io_buffer.h" | 14 #include "net/base/io_buffer.h" |
15 #include "net/base/load_flags.h" | 15 #include "net/base/load_flags.h" |
| 16 #include "net/base/registry_controlled_domains/registry_controlled_domain.h" |
16 #include "net/base/upload_bytes_element_reader.h" | 17 #include "net/base/upload_bytes_element_reader.h" |
17 #include "net/http/http_response_headers.h" | 18 #include "net/http/http_response_headers.h" |
18 #include "net/url_request/redirect_info.h" | 19 #include "net/url_request/redirect_info.h" |
19 #include "net/url_request/url_request_context.h" | 20 #include "net/url_request/url_request_context.h" |
20 | 21 |
21 namespace mojo { | 22 namespace mojo { |
22 namespace { | 23 namespace { |
23 | 24 |
| 25 GURL GetSiteForURL(const GURL& url) { |
| 26 // If the url has a host, then determine the site. |
| 27 if (url.has_host()) { |
| 28 // Only keep the scheme and registered domain as given by GetOrigin. This |
| 29 // may also include a port, which we need to drop. |
| 30 GURL site = url.GetOrigin(); |
| 31 |
| 32 // Remove port, if any. |
| 33 if (site.has_port()) { |
| 34 GURL::Replacements rep; |
| 35 rep.ClearPort(); |
| 36 site = site.ReplaceComponents(rep); |
| 37 } |
| 38 |
| 39 // If this URL has a registered domain, we only want to remember that part. |
| 40 std::string domain = net::registry_controlled_domains::GetDomainAndRegistry( |
| 41 url, net::registry_controlled_domains::INCLUDE_PRIVATE_REGISTRIES); |
| 42 if (!domain.empty()) { |
| 43 GURL::Replacements rep; |
| 44 rep.SetHostStr(domain); |
| 45 site = site.ReplaceComponents(rep); |
| 46 } |
| 47 return site; |
| 48 } |
| 49 |
| 50 // If there is no host but there is a scheme, return the scheme. |
| 51 // This is useful for cases like file URLs. |
| 52 if (url.has_scheme()) |
| 53 return GURL(url.scheme() + ":"); |
| 54 |
| 55 // Otherwise the URL should be invalid; return an empty site. |
| 56 DCHECK(!url.is_valid()); |
| 57 return GURL(); |
| 58 } |
| 59 |
24 // Generates an URLResponsePtr from the response state of a net::URLRequest. | 60 // Generates an URLResponsePtr from the response state of a net::URLRequest. |
25 URLResponsePtr MakeURLResponse(const net::URLRequest* url_request) { | 61 URLResponsePtr MakeURLResponse(const net::URLRequest* url_request) { |
26 URLResponsePtr response(URLResponse::New()); | 62 URLResponsePtr response(URLResponse::New()); |
27 response->url = String::From(url_request->url()); | 63 response->url = String::From(url_request->url()); |
| 64 response->site = GetSiteForURL(url_request->url()).spec(); |
28 | 65 |
29 const net::HttpResponseHeaders* headers = url_request->response_headers(); | 66 const net::HttpResponseHeaders* headers = url_request->response_headers(); |
30 if (headers) { | 67 if (headers) { |
31 response->status_code = headers->response_code(); | 68 response->status_code = headers->response_code(); |
32 response->status_line = headers->GetStatusLine(); | 69 response->status_line = headers->GetStatusLine(); |
33 | 70 |
34 response->headers = Array<HttpHeaderPtr>::New(0); | 71 response->headers = Array<HttpHeaderPtr>::New(0); |
35 std::vector<String> header_lines; | 72 std::vector<String> header_lines; |
36 void* iter = nullptr; | 73 void* iter = nullptr; |
37 std::string name, value; | 74 std::string name, value; |
(...skipping 328 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
366 | 403 |
367 void URLLoaderImpl::ListenForPeerClosed() { | 404 void URLLoaderImpl::ListenForPeerClosed() { |
368 handle_watcher_.Start(response_body_stream_.get(), | 405 handle_watcher_.Start(response_body_stream_.get(), |
369 MOJO_HANDLE_SIGNAL_PEER_CLOSED, | 406 MOJO_HANDLE_SIGNAL_PEER_CLOSED, |
370 MOJO_DEADLINE_INDEFINITE, | 407 MOJO_DEADLINE_INDEFINITE, |
371 base::Bind(&URLLoaderImpl::OnResponseBodyStreamClosed, | 408 base::Bind(&URLLoaderImpl::OnResponseBodyStreamClosed, |
372 base::Unretained(this))); | 409 base::Unretained(this))); |
373 } | 410 } |
374 | 411 |
375 } // namespace mojo | 412 } // namespace mojo |
OLD | NEW |