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 "content/browser/loader/navigation_resource_handler.h" | 5 #include "content/browser/loader/navigation_resource_handler.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "content/browser/devtools/devtools_netlog_observer.h" | 8 #include "content/browser/devtools/devtools_netlog_observer.h" |
9 #include "content/browser/loader/navigation_url_loader_impl_core.h" | 9 #include "content/browser/loader/navigation_url_loader_impl_core.h" |
10 #include "content/browser/loader/resource_request_info_impl.h" | 10 #include "content/browser/loader/resource_request_info_impl.h" |
11 #include "content/browser/resource_context_impl.h" | 11 #include "content/browser/resource_context_impl.h" |
12 #include "content/browser/streams/stream.h" | 12 #include "content/browser/streams/stream.h" |
13 #include "content/browser/streams/stream_context.h" | 13 #include "content/browser/streams/stream_context.h" |
14 #include "content/public/browser/resource_controller.h" | 14 #include "content/public/browser/resource_controller.h" |
15 #include "content/public/browser/stream_handle.h" | 15 #include "content/public/browser/stream_handle.h" |
16 #include "content/public/common/resource_response.h" | 16 #include "content/public/common/resource_response.h" |
17 #include "net/base/net_errors.h" | 17 #include "net/base/net_errors.h" |
18 #include "net/url_request/redirect_info.h" | |
18 #include "net/url_request/url_request.h" | 19 #include "net/url_request/url_request.h" |
20 #include "net/url_request/url_request_context.h" | |
21 #include "net/url_request/url_request_job_factory.h" | |
19 | 22 |
20 namespace content { | 23 namespace content { |
21 | 24 |
22 NavigationResourceHandler::NavigationResourceHandler( | 25 NavigationResourceHandler::NavigationResourceHandler( |
23 net::URLRequest* request, | 26 net::URLRequest* request, |
24 NavigationURLLoaderImplCore* core) | 27 NavigationURLLoaderImplCore* core) |
25 : ResourceHandler(request), | 28 : ResourceHandler(request), |
26 core_(core) { | 29 core_(core) { |
27 core_->set_resource_handler(this); | 30 core_->set_resource_handler(this); |
28 writer_.set_immediate_mode(true); | 31 writer_.set_immediate_mode(true); |
(...skipping 26 matching lines...) Expand all Loading... | |
55 | 58 |
56 bool NavigationResourceHandler::OnRequestRedirected( | 59 bool NavigationResourceHandler::OnRequestRedirected( |
57 const net::RedirectInfo& redirect_info, | 60 const net::RedirectInfo& redirect_info, |
58 ResourceResponse* response, | 61 ResourceResponse* response, |
59 bool* defer) { | 62 bool* defer) { |
60 DCHECK(core_); | 63 DCHECK(core_); |
61 | 64 |
62 // TODO(davidben): Perform a CSP check here, and anything else that would have | 65 // TODO(davidben): Perform a CSP check here, and anything else that would have |
63 // been done renderer-side. | 66 // been done renderer-side. |
64 DevToolsNetLogObserver::PopulateResponseInfo(request(), response); | 67 DevToolsNetLogObserver::PopulateResponseInfo(request(), response); |
65 core_->NotifyRequestRedirected(redirect_info, response); | 68 bool is_external_protocol = |
69 !request()->context()->job_factory()->IsHandledURL(redirect_info.new_url); | |
nasko
2015/09/04 23:36:49
Can some of those smaller bits, like propagating t
clamy
2015/09/08 16:27:19
I've taken out the is_external_protocol update par
| |
70 core_->NotifyRequestRedirected(redirect_info, response, is_external_protocol); | |
66 *defer = true; | 71 *defer = true; |
67 return true; | 72 return true; |
68 } | 73 } |
69 | 74 |
70 bool NavigationResourceHandler::OnResponseStarted(ResourceResponse* response, | 75 bool NavigationResourceHandler::OnResponseStarted(ResourceResponse* response, |
71 bool* defer) { | 76 bool* defer) { |
72 DCHECK(core_); | 77 DCHECK(core_); |
73 | 78 |
74 ResourceRequestInfoImpl* info = GetRequestInfo(); | 79 ResourceRequestInfoImpl* info = GetRequestInfo(); |
75 | 80 |
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
142 NOTREACHED(); | 147 NOTREACHED(); |
143 } | 148 } |
144 | 149 |
145 void NavigationResourceHandler::DetachFromCore() { | 150 void NavigationResourceHandler::DetachFromCore() { |
146 DCHECK(core_); | 151 DCHECK(core_); |
147 core_->set_resource_handler(nullptr); | 152 core_->set_resource_handler(nullptr); |
148 core_ = nullptr; | 153 core_ = nullptr; |
149 } | 154 } |
150 | 155 |
151 } // namespace content | 156 } // namespace content |
OLD | NEW |