| 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 "chrome/browser/extensions/api/web_request/web_request_api.h" | 5 #include "chrome/browser/extensions/api/web_request/web_request_api.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 21 matching lines...) Expand all Loading... |
| 32 #include "chrome/browser/extensions/extension_tab_id_map.h" | 32 #include "chrome/browser/extensions/extension_tab_id_map.h" |
| 33 #include "chrome/browser/extensions/extension_warning_service.h" | 33 #include "chrome/browser/extensions/extension_warning_service.h" |
| 34 #include "chrome/browser/extensions/extension_warning_set.h" | 34 #include "chrome/browser/extensions/extension_warning_set.h" |
| 35 #include "chrome/browser/profiles/profile.h" | 35 #include "chrome/browser/profiles/profile.h" |
| 36 #include "chrome/browser/profiles/profile_manager.h" | 36 #include "chrome/browser/profiles/profile_manager.h" |
| 37 #include "chrome/browser/renderer_host/chrome_render_message_filter.h" | 37 #include "chrome/browser/renderer_host/chrome_render_message_filter.h" |
| 38 #include "chrome/common/extensions/api/web_request.h" | 38 #include "chrome/common/extensions/api/web_request.h" |
| 39 #include "chrome/common/extensions/event_filtering_info.h" | 39 #include "chrome/common/extensions/event_filtering_info.h" |
| 40 #include "chrome/common/extensions/extension.h" | 40 #include "chrome/common/extensions/extension.h" |
| 41 #include "chrome/common/extensions/extension_constants.h" | 41 #include "chrome/common/extensions/extension_constants.h" |
| 42 #include "chrome/common/extensions/extension_error_utils.h" | |
| 43 #include "chrome/common/extensions/extension_messages.h" | 42 #include "chrome/common/extensions/extension_messages.h" |
| 44 #include "chrome/common/extensions/features/feature.h" | 43 #include "chrome/common/extensions/features/feature.h" |
| 45 #include "chrome/common/url_constants.h" | 44 #include "chrome/common/url_constants.h" |
| 46 #include "content/public/browser/browser_message_filter.h" | 45 #include "content/public/browser/browser_message_filter.h" |
| 47 #include "content/public/browser/browser_thread.h" | 46 #include "content/public/browser/browser_thread.h" |
| 48 #include "content/public/browser/render_process_host.h" | 47 #include "content/public/browser/render_process_host.h" |
| 49 #include "content/public/browser/resource_request_info.h" | 48 #include "content/public/browser/resource_request_info.h" |
| 49 #include "extensions/common/error_utils.h" |
| 50 #include "extensions/common/url_pattern.h" | 50 #include "extensions/common/url_pattern.h" |
| 51 #include "googleurl/src/gurl.h" | 51 #include "googleurl/src/gurl.h" |
| 52 #include "grit/generated_resources.h" | 52 #include "grit/generated_resources.h" |
| 53 #include "net/base/auth.h" | 53 #include "net/base/auth.h" |
| 54 #include "net/base/net_errors.h" | 54 #include "net/base/net_errors.h" |
| 55 #include "net/base/upload_data.h" | 55 #include "net/base/upload_data.h" |
| 56 #include "net/base/upload_element.h" | 56 #include "net/base/upload_element.h" |
| 57 #include "net/http/http_response_headers.h" | 57 #include "net/http/http_response_headers.h" |
| 58 #include "net/url_request/url_request.h" | 58 #include "net/url_request/url_request.h" |
| 59 #include "ui/base/l10n/l10n_util.h" | 59 #include "ui/base/l10n/l10n_util.h" |
| 60 | 60 |
| 61 using base::DictionaryValue; | 61 using base::DictionaryValue; |
| 62 using base::ListValue; | 62 using base::ListValue; |
| 63 using base::StringValue; | 63 using base::StringValue; |
| 64 using chrome::VersionInfo; | 64 using chrome::VersionInfo; |
| 65 using content::BrowserMessageFilter; | 65 using content::BrowserMessageFilter; |
| 66 using content::BrowserThread; | 66 using content::BrowserThread; |
| 67 using content::ResourceRequestInfo; | 67 using content::ResourceRequestInfo; |
| 68 using extensions::ErrorUtils; |
| 68 using extensions::Extension; | 69 using extensions::Extension; |
| 69 using extensions::ExtensionWarning; | 70 using extensions::ExtensionWarning; |
| 70 using extensions::ExtensionWarningService; | 71 using extensions::ExtensionWarningService; |
| 71 using extensions::ExtensionWarningSet; | 72 using extensions::ExtensionWarningSet; |
| 72 using extensions::Feature; | 73 using extensions::Feature; |
| 73 using extensions::web_navigation_api_helpers::GetFrameId; | 74 using extensions::web_navigation_api_helpers::GetFrameId; |
| 74 | 75 |
| 75 namespace helpers = extension_web_request_api_helpers; | 76 namespace helpers = extension_web_request_api_helpers; |
| 76 namespace keys = extension_web_request_api_constants; | 77 namespace keys = extension_web_request_api_constants; |
| 77 namespace web_request = extensions::api::web_request; | 78 namespace web_request = extensions::api::web_request; |
| (...skipping 332 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 410 if (!value.GetList("urls", &urls_value)) | 411 if (!value.GetList("urls", &urls_value)) |
| 411 return false; | 412 return false; |
| 412 for (size_t i = 0; i < urls_value->GetSize(); ++i) { | 413 for (size_t i = 0; i < urls_value->GetSize(); ++i) { |
| 413 std::string url; | 414 std::string url; |
| 414 URLPattern pattern( | 415 URLPattern pattern( |
| 415 URLPattern::SCHEME_HTTP | URLPattern::SCHEME_HTTPS | | 416 URLPattern::SCHEME_HTTP | URLPattern::SCHEME_HTTPS | |
| 416 URLPattern::SCHEME_FTP | URLPattern::SCHEME_FILE | | 417 URLPattern::SCHEME_FTP | URLPattern::SCHEME_FILE | |
| 417 URLPattern::SCHEME_EXTENSION); | 418 URLPattern::SCHEME_EXTENSION); |
| 418 if (!urls_value->GetString(i, &url) || | 419 if (!urls_value->GetString(i, &url) || |
| 419 pattern.Parse(url) != URLPattern::PARSE_SUCCESS) { | 420 pattern.Parse(url) != URLPattern::PARSE_SUCCESS) { |
| 420 *error = ExtensionErrorUtils::FormatErrorMessage( | 421 *error = ErrorUtils::FormatErrorMessage( |
| 421 keys::kInvalidRequestFilterUrl, url); | 422 keys::kInvalidRequestFilterUrl, url); |
| 422 return false; | 423 return false; |
| 423 } | 424 } |
| 424 urls.AddPattern(pattern); | 425 urls.AddPattern(pattern); |
| 425 } | 426 } |
| 426 } else if (*key == "types") { | 427 } else if (*key == "types") { |
| 427 const ListValue* types_value = NULL; | 428 const ListValue* types_value = NULL; |
| 428 if (!value.GetList("types", &types_value)) | 429 if (!value.GetList("types", &types_value)) |
| 429 return false; | 430 return false; |
| 430 for (size_t i = 0; i < types_value->GetSize(); ++i) { | 431 for (size_t i = 0; i < types_value->GetSize(); ++i) { |
| (...skipping 1355 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1786 EXTENSION_FUNCTION_VALIDATE(value->GetBoolean("cancel", &cancel)); | 1787 EXTENSION_FUNCTION_VALIDATE(value->GetBoolean("cancel", &cancel)); |
| 1787 response->cancel = cancel; | 1788 response->cancel = cancel; |
| 1788 } | 1789 } |
| 1789 | 1790 |
| 1790 if (value->HasKey("redirectUrl")) { | 1791 if (value->HasKey("redirectUrl")) { |
| 1791 std::string new_url_str; | 1792 std::string new_url_str; |
| 1792 EXTENSION_FUNCTION_VALIDATE(value->GetString("redirectUrl", | 1793 EXTENSION_FUNCTION_VALIDATE(value->GetString("redirectUrl", |
| 1793 &new_url_str)); | 1794 &new_url_str)); |
| 1794 response->new_url = GURL(new_url_str); | 1795 response->new_url = GURL(new_url_str); |
| 1795 if (!response->new_url.is_valid()) { | 1796 if (!response->new_url.is_valid()) { |
| 1796 error_ = ExtensionErrorUtils::FormatErrorMessage( | 1797 error_ = ErrorUtils::FormatErrorMessage( |
| 1797 keys::kInvalidRedirectUrl, new_url_str); | 1798 keys::kInvalidRedirectUrl, new_url_str); |
| 1798 return false; | 1799 return false; |
| 1799 } | 1800 } |
| 1800 } | 1801 } |
| 1801 | 1802 |
| 1802 if (value->HasKey("requestHeaders")) { | 1803 if (value->HasKey("requestHeaders")) { |
| 1803 ListValue* request_headers_value = NULL; | 1804 ListValue* request_headers_value = NULL; |
| 1804 response->request_headers.reset(new net::HttpRequestHeaders()); | 1805 response->request_headers.reset(new net::HttpRequestHeaders()); |
| 1805 EXTENSION_FUNCTION_VALIDATE(value->GetList(keys::kRequestHeadersKey, | 1806 EXTENSION_FUNCTION_VALIDATE(value->GetList(keys::kRequestHeadersKey, |
| 1806 &request_headers_value)); | 1807 &request_headers_value)); |
| (...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1911 } else if ((*it)->name().find("AdBlock") != std::string::npos) { | 1912 } else if ((*it)->name().find("AdBlock") != std::string::npos) { |
| 1912 adblock = true; | 1913 adblock = true; |
| 1913 } else { | 1914 } else { |
| 1914 other = true; | 1915 other = true; |
| 1915 } | 1916 } |
| 1916 } | 1917 } |
| 1917 } | 1918 } |
| 1918 | 1919 |
| 1919 host->Send(new ExtensionMsg_UsingWebRequestAPI(adblock, adblock_plus, other)); | 1920 host->Send(new ExtensionMsg_UsingWebRequestAPI(adblock, adblock_plus, other)); |
| 1920 } | 1921 } |
| OLD | NEW |