| OLD | NEW |
| 1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 // See http://dev.chromium.org/developers/design-documents/multi-process-resourc
e-loading | 5 // See http://dev.chromium.org/developers/design-documents/multi-process-resourc
e-loading |
| 6 | 6 |
| 7 #include "chrome/browser/renderer_host/resource_dispatcher_host.h" | 7 #include "chrome/browser/renderer_host/resource_dispatcher_host.h" |
| 8 | 8 |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 581 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 592 params.closing_route_id, | 592 params.closing_route_id, |
| 593 &RenderViewHost::ClosePageIgnoringUnloadEvents); | 593 &RenderViewHost::ClosePageIgnoringUnloadEvents); |
| 594 } | 594 } |
| 595 } | 595 } |
| 596 | 596 |
| 597 // We are explicitly forcing the download of 'url'. | 597 // We are explicitly forcing the download of 'url'. |
| 598 void ResourceDispatcherHost::BeginDownload( | 598 void ResourceDispatcherHost::BeginDownload( |
| 599 const GURL& url, | 599 const GURL& url, |
| 600 const GURL& referrer, | 600 const GURL& referrer, |
| 601 const DownloadSaveInfo& save_info, | 601 const DownloadSaveInfo& save_info, |
| 602 bool prompt_for_save_location, |
| 602 int child_id, | 603 int child_id, |
| 603 int route_id, | 604 int route_id, |
| 604 URLRequestContext* request_context) { | 605 URLRequestContext* request_context) { |
| 605 if (is_shutdown_) | 606 if (is_shutdown_) |
| 606 return; | 607 return; |
| 607 | 608 |
| 608 // Check if the renderer is permitted to request the requested URL. | 609 // Check if the renderer is permitted to request the requested URL. |
| 609 if (!ChildProcessSecurityPolicy::GetInstance()-> | 610 if (!ChildProcessSecurityPolicy::GetInstance()-> |
| 610 CanRequestURL(child_id, url)) { | 611 CanRequestURL(child_id, url)) { |
| 611 LOG(INFO) << "Denied unauthorized download request for " << | 612 LOG(INFO) << "Denied unauthorized download request for " << |
| 612 url.possibly_invalid_spec(); | 613 url.possibly_invalid_spec(); |
| 613 return; | 614 return; |
| 614 } | 615 } |
| 615 | 616 |
| 616 // Ensure the Chrome plugins are loaded, as they may intercept network | 617 // Ensure the Chrome plugins are loaded, as they may intercept network |
| 617 // requests. Does nothing if they are already loaded. | 618 // requests. Does nothing if they are already loaded. |
| 618 PluginService::GetInstance()->LoadChromePlugins(this); | 619 PluginService::GetInstance()->LoadChromePlugins(this); |
| 619 URLRequest* request = new URLRequest(url, this); | 620 URLRequest* request = new URLRequest(url, this); |
| 620 | 621 |
| 621 request_id_--; | 622 request_id_--; |
| 622 | 623 |
| 623 scoped_refptr<ResourceHandler> handler = | 624 scoped_refptr<ResourceHandler> handler = |
| 624 new DownloadResourceHandler(this, | 625 new DownloadResourceHandler(this, |
| 625 child_id, | 626 child_id, |
| 626 route_id, | 627 route_id, |
| 627 request_id_, | 628 request_id_, |
| 628 url, | 629 url, |
| 629 download_file_manager_.get(), | 630 download_file_manager_.get(), |
| 630 request, | 631 request, |
| 631 true, | 632 prompt_for_save_location, |
| 632 save_info); | 633 save_info); |
| 633 | 634 |
| 634 if (safe_browsing_->enabled()) { | 635 if (safe_browsing_->enabled()) { |
| 635 handler = CreateSafeBrowsingResourceHandler(handler, child_id, route_id, | 636 handler = CreateSafeBrowsingResourceHandler(handler, child_id, route_id, |
| 636 ResourceType::MAIN_FRAME); | 637 ResourceType::MAIN_FRAME); |
| 637 } | 638 } |
| 638 | 639 |
| 639 if (!URLRequest::IsHandledURL(url)) { | 640 if (!URLRequest::IsHandledURL(url)) { |
| 640 LOG(INFO) << "Download request for unsupported protocol: " << | 641 LOG(INFO) << "Download request for unsupported protocol: " << |
| 641 url.possibly_invalid_spec(); | 642 url.possibly_invalid_spec(); |
| (...skipping 1179 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1821 // them. | 1822 // them. |
| 1822 case ResourceType::IMAGE: | 1823 case ResourceType::IMAGE: |
| 1823 return net::LOWEST; | 1824 return net::LOWEST; |
| 1824 | 1825 |
| 1825 default: | 1826 default: |
| 1826 // When new resource types are added, their priority must be considered. | 1827 // When new resource types are added, their priority must be considered. |
| 1827 NOTREACHED(); | 1828 NOTREACHED(); |
| 1828 return net::LOW; | 1829 return net::LOW; |
| 1829 } | 1830 } |
| 1830 } | 1831 } |
| OLD | NEW |