Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 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 | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "content/browser/loader/navigation_resource_handler.h" | |
| 6 | |
| 7 #include "base/logging.h" | |
| 8 #include "content/browser/devtools/devtools_netlog_observer.h" | |
| 9 #include "content/browser/loader/navigation_url_loader_core.h" | |
| 10 #include "content/browser/loader/resource_request_info_impl.h" | |
| 11 #include "content/browser/resource_context_impl.h" | |
| 12 #include "content/browser/streams/stream.h" | |
| 13 #include "content/browser/streams/stream_context.h" | |
| 14 #include "content/public/browser/resource_controller.h" | |
| 15 #include "content/public/browser/stream_handle.h" | |
| 16 #include "content/public/common/resource_response.h" | |
| 17 #include "net/base/net_errors.h" | |
| 18 #include "net/url_request/url_request.h" | |
| 19 | |
| 20 namespace content { | |
| 21 | |
| 22 NavigationResourceHandler::NavigationResourceHandler( | |
| 23 net::URLRequest* request, | |
| 24 NavigationURLLoaderCore* core) | |
| 25 : ResourceHandler(request), | |
| 26 core_(core) { | |
| 27 core_->set_resource_handler(this); | |
| 28 } | |
| 29 | |
| 30 NavigationResourceHandler::~NavigationResourceHandler() { | |
| 31 if (core_) { | |
| 32 core_->NotifyRequestFailed(net::ERR_ABORTED); | |
|
mmenke
2014/10/22 15:32:58
Can we end up here without an OnResponseCompleted
davidben
2014/10/22 20:58:03
If the ResourceLoader is uncleanly torn down, it c
| |
| 33 core_->set_resource_handler(nullptr); | |
| 34 core_ = nullptr; | |
|
mmenke
2014/10/22 15:32:58
I don't think this gets us anything.
davidben
2014/10/22 20:58:03
Moved into helper method.
| |
| 35 } | |
| 36 } | |
| 37 | |
| 38 void NavigationResourceHandler::Cancel() { | |
| 39 controller()->Cancel(); | |
| 40 core_ = nullptr; | |
| 41 } | |
| 42 | |
| 43 void NavigationResourceHandler::FollowRedirect() { | |
| 44 controller()->Resume(); | |
| 45 } | |
| 46 | |
| 47 void NavigationResourceHandler::SetController(ResourceController* controller) { | |
| 48 writer_.set_controller(controller); | |
| 49 ResourceHandler::SetController(controller); | |
| 50 } | |
| 51 | |
| 52 bool NavigationResourceHandler::OnUploadProgress(uint64 position, | |
| 53 uint64 size) { | |
| 54 return true; | |
| 55 } | |
| 56 | |
| 57 bool NavigationResourceHandler::OnRequestRedirected( | |
| 58 const net::RedirectInfo& redirect_info, | |
| 59 ResourceResponse* response, | |
| 60 bool* defer) { | |
| 61 if (!core_) | |
|
mmenke
2014/10/22 15:32:58
Can this happen? We would have cancelled it by th
davidben
2014/10/22 20:58:04
I'm never clear on what can happen with all our as
| |
| 62 return false; | |
| 63 | |
| 64 // TODO(davidben): Perform a CSP check here, and anything else that would have | |
| 65 // been done renderer-side. | |
| 66 DevToolsNetLogObserver::PopulateResponseInfo(request(), response); | |
| 67 core_->NotifyRequestRedirected(redirect_info, response); | |
| 68 *defer = true; | |
| 69 return true; | |
| 70 } | |
| 71 | |
| 72 bool NavigationResourceHandler::OnResponseStarted(ResourceResponse* response, | |
| 73 bool* defer) { | |
| 74 if (!core_) | |
| 75 return false; | |
| 76 | |
| 77 ResourceRequestInfoImpl* info = GetRequestInfo(); | |
| 78 | |
| 79 // If the BufferedResourceHandler intercepted this request and converted it | |
| 80 // into a download, it will still call OnResponseStarted and immediately | |
| 81 // cancel. Ignore the call; OnReadCompleted will happen shortly. | |
| 82 // | |
| 83 // TODO(davidben): Move the dispatch out of BufferedResourceHandler. Perhaps | |
| 84 // all the way to the UI thread. Downloads, user certificates, etc., should be | |
| 85 // dispatched at the navigation layer. | |
| 86 if (info->IsDownload() || info->is_stream()) | |
| 87 return true; | |
| 88 | |
| 89 StreamContext* stream_context = | |
| 90 GetStreamContextForResourceContext(info->GetContext()); | |
| 91 writer_.InitializeStream(stream_context->registry(), | |
| 92 request()->url().GetOrigin()); | |
| 93 | |
| 94 // Detach from the loader; at this point, the request is now owned by the | |
| 95 // StreamHandle. | |
| 96 DevToolsNetLogObserver::PopulateResponseInfo(request(), response); | |
| 97 core_->NotifyResponseStarted(response, writer_.stream()->CreateHandle()); | |
| 98 core_->set_resource_handler(nullptr); | |
| 99 core_ = nullptr; | |
| 100 return true; | |
| 101 } | |
| 102 | |
| 103 bool NavigationResourceHandler::OnWillStart(const GURL& url, bool* defer) { | |
| 104 return true; | |
| 105 } | |
| 106 | |
| 107 bool NavigationResourceHandler::OnBeforeNetworkStart(const GURL& url, | |
| 108 bool* defer) { | |
| 109 return true; | |
| 110 } | |
| 111 | |
| 112 bool NavigationResourceHandler::OnWillRead(scoped_refptr<net::IOBuffer>* buf, | |
| 113 int* buf_size, | |
| 114 int min_size) { | |
| 115 writer_.OnWillRead(buf, buf_size, min_size); | |
| 116 return true; | |
| 117 } | |
| 118 | |
| 119 bool NavigationResourceHandler::OnReadCompleted(int bytes_read, bool* defer) { | |
| 120 writer_.OnReadCompleted(bytes_read, defer); | |
| 121 return true; | |
| 122 } | |
| 123 | |
| 124 void NavigationResourceHandler::OnResponseCompleted( | |
| 125 const net::URLRequestStatus& status, | |
| 126 const std::string& security_info, | |
| 127 bool* defer) { | |
| 128 // If the request has already committed, close the stream and leave it as-is. | |
| 129 // | |
| 130 // TODO(davidben): Is the final status of a navigation request meaningful? | |
| 131 // Perhaps we should eventually extend the streams interface to push the | |
| 132 // status down. (If there was an error partway through loading the top-level.) | |
|
mmenke
2014/10/22 15:32:58
Do we currently replace committed partially loaded
davidben
2014/10/22 20:58:04
No, but it apparently isn't a no-op as far as Blin
| |
| 133 if (writer_.stream()) { | |
| 134 writer_.Finalize(); | |
|
mmenke
2014/10/22 15:32:58
Telling WebKit a blob is happily completed on erro
davidben
2014/10/22 20:58:04
Left a TODO and filed https://crbug.com/426162
| |
| 135 return; | |
| 136 } | |
| 137 | |
| 138 if (core_) { | |
| 139 DCHECK_NE(net::OK, status.error()); | |
| 140 core_->NotifyRequestFailed(status.error()); | |
| 141 core_->set_resource_handler(nullptr); | |
| 142 core_ = nullptr; | |
|
mmenke
2014/10/22 15:32:58
Are the last two lines needed? We end up destroyi
davidben
2014/10/22 20:58:04
If we don't detach at this point, then the destruc
| |
| 143 } | |
| 144 } | |
| 145 | |
| 146 void NavigationResourceHandler::OnDataDownloaded(int bytes_downloaded) { | |
| 147 NOTREACHED(); | |
| 148 } | |
| 149 | |
| 150 } // namespace content | |
| OLD | NEW |