Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(772)

Side by Side Diff: chrome/browser/extensions/extension_protocols.cc

Issue 11821009: move 'web_accessible_resources' parsing out of Extension class. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@url_parse
Patch Set: Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/extension_protocols.h" 5 #include "chrome/browser/extensions/extension_protocols.h"
6 6
7 #include <algorithm> 7 #include <algorithm>
8 8
9 #include "base/compiler_specific.h" 9 #include "base/compiler_specific.h"
10 #include "base/file_path.h" 10 #include "base/file_path.h"
11 #include "base/logging.h" 11 #include "base/logging.h"
12 #include "base/memory/weak_ptr.h" 12 #include "base/memory/weak_ptr.h"
13 #include "base/message_loop.h" 13 #include "base/message_loop.h"
14 #include "base/path_service.h" 14 #include "base/path_service.h"
15 #include "base/string_util.h" 15 #include "base/string_util.h"
16 #include "base/stringprintf.h" 16 #include "base/stringprintf.h"
17 #include "base/threading/thread_restrictions.h" 17 #include "base/threading/thread_restrictions.h"
18 #include "base/threading/worker_pool.h" 18 #include "base/threading/worker_pool.h"
19 #include "build/build_config.h" 19 #include "build/build_config.h"
20 #include "chrome/browser/extensions/extension_info_map.h" 20 #include "chrome/browser/extensions/extension_info_map.h"
21 #include "chrome/browser/extensions/image_loader.h" 21 #include "chrome/browser/extensions/image_loader.h"
22 #include "chrome/browser/net/chrome_url_request_context.h" 22 #include "chrome/browser/net/chrome_url_request_context.h"
23 #include "chrome/common/chrome_paths.h" 23 #include "chrome/common/chrome_paths.h"
24 #include "chrome/common/extensions/extension.h" 24 #include "chrome/common/extensions/extension.h"
25 #include "chrome/common/extensions/extension_file_util.h" 25 #include "chrome/common/extensions/extension_file_util.h"
26 #include "chrome/common/extensions/extension_resource.h" 26 #include "chrome/common/extensions/extension_resource.h"
27 #include "chrome/common/extensions/manifest_web_handler.h"
27 #include "chrome/common/url_constants.h" 28 #include "chrome/common/url_constants.h"
28 #include "content/public/browser/resource_request_info.h" 29 #include "content/public/browser/resource_request_info.h"
29 #include "extensions/common/constants.h" 30 #include "extensions/common/constants.h"
30 #include "googleurl/src/url_util.h" 31 #include "googleurl/src/url_util.h"
31 #include "grit/component_extension_resources_map.h" 32 #include "grit/component_extension_resources_map.h"
32 #include "net/base/mime_util.h" 33 #include "net/base/mime_util.h"
33 #include "net/base/net_errors.h" 34 #include "net/base/net_errors.h"
34 #include "net/http/http_response_headers.h" 35 #include "net/http/http_response_headers.h"
35 #include "net/http/http_response_info.h" 36 #include "net/http/http_response_info.h"
36 #include "net/url_request/url_request_error_job.h" 37 #include "net/url_request/url_request_error_job.h"
(...skipping 309 matching lines...) Expand 10 before | Expand all | Expand 10 after
346 } 347 }
347 } 348 }
348 349
349 std::string content_security_policy; 350 std::string content_security_policy;
350 bool send_cors_header = false; 351 bool send_cors_header = false;
351 if (extension) { 352 if (extension) {
352 std::string resource_path = request->url().path(); 353 std::string resource_path = request->url().path();
353 content_security_policy = 354 content_security_policy =
354 extension->GetResourceContentSecurityPolicy(resource_path); 355 extension->GetResourceContentSecurityPolicy(resource_path);
355 if ((extension->manifest_version() >= 2 || 356 if ((extension->manifest_version() >= 2 ||
356 extension->HasWebAccessibleResources()) && 357 extensions::WebAccessibleResourcesInfo::HasWebAccessibleResources(
Yoyo Zhou 2013/01/10 00:37:58 nit: this indent is wrong; it should align with th
Joe Thomas 2013/01/10 20:56:18 Done
357 extension->IsResourceWebAccessible(resource_path)) 358 extension)) &&
359 extensions::WebAccessibleResourcesInfo::IsResourceWebAccessible(
360 resource_path, extension))
358 send_cors_header = true; 361 send_cors_header = true;
359 } 362 }
360 363
361 std::string path = request->url().path(); 364 std::string path = request->url().path();
362 if (path.size() > 1 && 365 if (path.size() > 1 &&
363 path.substr(1) == extension_filenames::kGeneratedBackgroundPageFilename) { 366 path.substr(1) == extension_filenames::kGeneratedBackgroundPageFilename) {
364 return new GeneratedBackgroundPageJob( 367 return new GeneratedBackgroundPageJob(
365 request, network_delegate, extension, content_security_policy); 368 request, network_delegate, extension, content_security_policy);
366 } 369 }
367 370
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after
400 send_cors_header); 403 send_cors_header);
401 } 404 }
402 405
403 } // namespace 406 } // namespace
404 407
405 net::URLRequestJobFactory::ProtocolHandler* CreateExtensionProtocolHandler( 408 net::URLRequestJobFactory::ProtocolHandler* CreateExtensionProtocolHandler(
406 bool is_incognito, 409 bool is_incognito,
407 ExtensionInfoMap* extension_info_map) { 410 ExtensionInfoMap* extension_info_map) {
408 return new ExtensionProtocolHandler(is_incognito, extension_info_map); 411 return new ExtensionProtocolHandler(is_incognito, extension_info_map);
409 } 412 }
OLDNEW
« no previous file with comments | « no previous file | chrome/browser/extensions/manifest_web_parser.h » ('j') | chrome/browser/extensions/manifest_web_parser.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698