Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / chrome / common / extensions / docs / templates / articles / manifest / web_accessible_resources.html
blob418d7b84585ecf5dc62f8b758d665277e07e4089
1 <h1 id="web_accessible_resources">Manifest - Web Accessible Resources</h1>
3 <p>
4 An array of strings specifying the paths of packaged resources that are expected
5 to be usable in the context of a web page. These paths are relative to the package
6 root, and may contain wildcards.
7 For example, an extension that injects a content script with the intention of
8 building up some custom interface for <code>example.com</code> would whitelist
9 any resources that interface requires (images, icons, stylesheets, scripts,
10 etc.) as follows:
11 </p>
13 <pre data-filename="manifest.json">
15 ...
16 "web_accessible_resources": [
17 "images/*.png",
18 "style/double-rainbow.css",
19 "script/double-rainbow.js",
20 "script/main.js",
21 "templates/*"
23 ...
25 </pre>
27 <p>
28 These resources would then be available in a webpage via the URL
29 <code>chrome-extension://[PACKAGE ID]/[PATH]</code>, which can be generated with
30 the <a href="http://developer.chrome.com/extensions/extension#method-getURL">extension.getURL</a> method. Whitelisted resources are served with appropriate
31 <a href="http://www.w3.org/TR/cors/">CORS</a> headers, so they're available via
32 mechanisms like XHR.
33 </p>
35 <p>
36 A navigation from a web origin to an extension resource will be blocked unless
37 the resource is listed as web accessible. Note these corner cases:
38 </p>
39 <ul>
40 <li>When an extension uses the $(ref:webRequest) or $(ref:declarativeWebRequest)
41 APIs to redirect a public resource request to a resource that is not web
42 accessible, such request is also blocked.</li>
43 <li>The above holds true even if the resource that is not web accessible is
44 owned by the redirecting extension.</li>
45 </ul>
47 <p>
48 <a href="http://developer.chrome.com/extensions/content_scripts">Content scripts</a> themselves do not need to be whitelisted.
49 </p>
51 <p>
52 Prior to manifest version 2 all resources within an extension could be accessed
53 from any page on the web. This allowed a malicious website to
54 <a href="http://en.wikipedia.org/wiki/Device_fingerprint">fingerprint</a> the
55 extensions that a user has installed or exploit vulnerabilities (for example
56 <a href="http://en.wikipedia.org/wiki/Cross-site_scripting">XSS bugs</a>) within
57 installed extensions. Limiting availability to only resources which are
58 explicitly intended to be web accessible serves to both minimize the available
59 attack surface and protect the privacy of users.
60 </p>
62 <h2 id="availability">Default Availability</h2>
64 <p>
65 Resources inside of packages using <a href="http://developer.chrome.com/extensions/manifest#manifest_version"><code>manifest_version</code></a>
66 2 or above are <strong>blocked by default</strong>, and must be whitelisted
67 for use via this property.
68 </p>
70 <p>
71 Resources inside of packages using <code>manifest_version</code> 1 are available
72 by default, but <em>if</em> you do set this property, then it will be treated as
73 a complete list of all whitelisted resources. Resources not listed will be
74 blocked.
75 </p>