OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "net/url_request/url_request_job_manager.h" | 5 #include "net/url_request/url_request_job_manager.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 | 8 |
9 #include "base/memory/singleton.h" | 9 #include "base/memory/singleton.h" |
10 #include "build/build_config.h" | 10 #include "build/build_config.h" |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
72 request, network_delegate, ERR_UNKNOWN_URL_SCHEME); | 72 request, network_delegate, ERR_UNKNOWN_URL_SCHEME); |
73 } | 73 } |
74 | 74 |
75 // THREAD-SAFETY NOTICE: | 75 // THREAD-SAFETY NOTICE: |
76 // We do not need to acquire the lock here since we are only reading our | 76 // We do not need to acquire the lock here since we are only reading our |
77 // data structures. They should only be modified on the current thread. | 77 // data structures. They should only be modified on the current thread. |
78 | 78 |
79 // See if the request should be intercepted. | 79 // See if the request should be intercepted. |
80 // | 80 // |
81 | 81 |
82 if (job_factory) { | 82 // TODO(pauljensen): Remove this when AppCacheInterceptor is a |
83 URLRequestJob* job = job_factory->MaybeCreateJobWithInterceptor( | 83 // ProtocolHandler, see crbug.com/161547. |
84 request, network_delegate); | |
85 if (job) | |
86 return job; | |
87 } | |
88 | |
89 // TODO(willchan): Remove this in favor of URLRequestJobFactory::Interceptor. | |
90 if (!(request->load_flags() & LOAD_DISABLE_INTERCEPT)) { | 84 if (!(request->load_flags() & LOAD_DISABLE_INTERCEPT)) { |
91 InterceptorList::const_iterator i; | 85 InterceptorList::const_iterator i; |
92 for (i = interceptors_.begin(); i != interceptors_.end(); ++i) { | 86 for (i = interceptors_.begin(); i != interceptors_.end(); ++i) { |
93 URLRequestJob* job = (*i)->MaybeIntercept(request, network_delegate); | 87 URLRequestJob* job = (*i)->MaybeIntercept(request, network_delegate); |
94 if (job) | 88 if (job) |
95 return job; | 89 return job; |
96 } | 90 } |
97 } | 91 } |
98 | 92 |
99 if (job_factory) { | 93 if (job_factory) { |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
148 | 142 |
149 const std::string& scheme = request->url().scheme(); // already lowercase | 143 const std::string& scheme = request->url().scheme(); // already lowercase |
150 if (job_factory) { | 144 if (job_factory) { |
151 if (!job_factory->IsHandledProtocol(scheme)) { | 145 if (!job_factory->IsHandledProtocol(scheme)) { |
152 return NULL; | 146 return NULL; |
153 } | 147 } |
154 } else if (!SupportsScheme(scheme)) { | 148 } else if (!SupportsScheme(scheme)) { |
155 return NULL; | 149 return NULL; |
156 } | 150 } |
157 | 151 |
158 URLRequestJob* job = NULL; | |
159 if (job_factory) | |
160 job = job_factory->MaybeInterceptRedirect( | |
161 location, request, network_delegate); | |
162 if (job) | |
163 return job; | |
164 | |
165 InterceptorList::const_iterator i; | 152 InterceptorList::const_iterator i; |
166 for (i = interceptors_.begin(); i != interceptors_.end(); ++i) { | 153 for (i = interceptors_.begin(); i != interceptors_.end(); ++i) { |
167 job = (*i)->MaybeInterceptRedirect(request, network_delegate, location); | 154 URLRequestJob* job = (*i)->MaybeInterceptRedirect(request, |
| 155 network_delegate, |
| 156 location); |
168 if (job) | 157 if (job) |
169 return job; | 158 return job; |
170 } | 159 } |
171 return NULL; | 160 return NULL; |
172 } | 161 } |
173 | 162 |
174 URLRequestJob* URLRequestJobManager::MaybeInterceptResponse( | 163 URLRequestJob* URLRequestJobManager::MaybeInterceptResponse( |
175 URLRequest* request, NetworkDelegate* network_delegate) const { | 164 URLRequest* request, NetworkDelegate* network_delegate) const { |
176 DCHECK(IsAllowedThread()); | 165 DCHECK(IsAllowedThread()); |
177 if (!request->url().is_valid() || | 166 if (!request->url().is_valid() || |
178 request->load_flags() & LOAD_DISABLE_INTERCEPT || | 167 request->load_flags() & LOAD_DISABLE_INTERCEPT || |
179 request->status().status() == URLRequestStatus::CANCELED) { | 168 request->status().status() == URLRequestStatus::CANCELED) { |
180 return NULL; | 169 return NULL; |
181 } | 170 } |
182 | 171 |
183 const URLRequestJobFactory* job_factory = NULL; | 172 const URLRequestJobFactory* job_factory = NULL; |
184 job_factory = request->context()->job_factory(); | 173 job_factory = request->context()->job_factory(); |
185 | 174 |
186 const std::string& scheme = request->url().scheme(); // already lowercase | 175 const std::string& scheme = request->url().scheme(); // already lowercase |
187 if (job_factory) { | 176 if (job_factory) { |
188 if (!job_factory->IsHandledProtocol(scheme)) { | 177 if (!job_factory->IsHandledProtocol(scheme)) { |
189 return NULL; | 178 return NULL; |
190 } | 179 } |
191 } else if (!SupportsScheme(scheme)) { | 180 } else if (!SupportsScheme(scheme)) { |
192 return NULL; | 181 return NULL; |
193 } | 182 } |
194 | 183 |
195 URLRequestJob* job = NULL; | |
196 if (job_factory) | |
197 job = job_factory->MaybeInterceptResponse(request, network_delegate); | |
198 if (job) | |
199 return job; | |
200 | |
201 InterceptorList::const_iterator i; | 184 InterceptorList::const_iterator i; |
202 for (i = interceptors_.begin(); i != interceptors_.end(); ++i) { | 185 for (i = interceptors_.begin(); i != interceptors_.end(); ++i) { |
203 job = (*i)->MaybeInterceptResponse(request, network_delegate); | 186 URLRequestJob* job = (*i)->MaybeInterceptResponse(request, |
| 187 network_delegate); |
204 if (job) | 188 if (job) |
205 return job; | 189 return job; |
206 } | 190 } |
207 return NULL; | 191 return NULL; |
208 } | 192 } |
209 | 193 |
210 bool URLRequestJobManager::SupportsScheme(const std::string& scheme) const { | 194 bool URLRequestJobManager::SupportsScheme(const std::string& scheme) const { |
211 // The set of registered factories may change on another thread. | 195 // The set of registered factories may change on another thread. |
212 { | 196 { |
213 base::AutoLock locked(lock_); | 197 base::AutoLock locked(lock_); |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
268 } | 252 } |
269 | 253 |
270 URLRequestJobManager::URLRequestJobManager() | 254 URLRequestJobManager::URLRequestJobManager() |
271 : allowed_thread_(0), | 255 : allowed_thread_(0), |
272 allowed_thread_initialized_(false) { | 256 allowed_thread_initialized_(false) { |
273 } | 257 } |
274 | 258 |
275 URLRequestJobManager::~URLRequestJobManager() {} | 259 URLRequestJobManager::~URLRequestJobManager() {} |
276 | 260 |
277 } // namespace net | 261 } // namespace net |
OLD | NEW |