1 <h1>Permission Warnings
</h1>
5 NOTE: When this doc is updated, the online help should also be updated:
6 https://support.google.com/chrome_webstore/answer/186213
8 We should periodically look at
9 http://src.chromium.org/viewvc/chrome/trunk/src/chrome/app/generated_resources.grd?view=markup
10 to make sure that we're covering all messages. Search for
11 IDS_EXTENSION_PROMPT_WARNING
12 (e.g. IDS_EXTENSION_PROMPT_WARNING_BROWSING_HISTORY).
16 To use most chrome.* APIs and extension capabilities,
17 your extension must declare its intent in the
18 <a href=
"manifest">manifest
</a>,
19 often in the
"permissions" field.
20 Some of these declarations
21 result in a warning when
22 a user installs your extension.
26 When you autoupdate your extension,
27 the user might see another warning
28 if the extension requests new permissions.
29 These new permissions might be new APIs that your extension uses,
30 or they might be new websites
31 that your extension needs access to.
35 <h2 id=
"examples"> Examples of permission warnings
</h2>
38 Here's a typical dialog
39 that a user might see when installing an extension:
42 <img src=
"{{static}}/images/perms-hw1.png"
43 width=
"490" height=
"193"
44 alt=
"Permission warning: 'It can: Read and modify your data on api.flickr.com'"
48 The warning about access to data on api.flickr.com
49 is caused by the following lines
50 in the extension's manifest:
53 <pre data-filename=
"manifest.json">
55 <b>"http://api.flickr.com/"</b>
61 You don't see permission warnings when
62 you load an unpacked extension.
63 You get permission warnings only when you install an extension
64 from a
<code>.crx
</code> file.
68 If you add a permission to the extension when you autoupdate it,
69 the user might see a new permission warning.
71 assume you add a new site and the
"tabs" permission
72 to the previous example:
75 <pre data-filename=
"manifest.json">
77 "http://api.flickr.com/",
78 <b>"http://*.flickr.com/",
84 When the extension autoupdates,
85 the increased permissions
86 cause the extension to be disabled
87 until the user re-enables it.
88 Here's the warning the user sees:
91 <img src=
"{{static}}/images/perms-hw2-disabled.png"
92 width=
"332" height=
"208"
93 alt=
"Warning text: 'The newest version of the extension Hello World requires more permissions, so it has been disabled. [Re-enable].'"
97 Clicking the Re-enable button
98 brings up the following warning:
101 <img src=
"{{static}}/images/perms-hw2.png"
102 width=
"490" height=
"193"
103 alt=
"Permission warning: 'It can: Read and modify your data on api.flickr.com; Access your browsing activity'"
107 <h2 id=
"warnings"> Warnings and their triggers
</h2>
111 It can be surprising when adding a permission such as
"tabs"
112 results in the seemingly unrelated warning
113 that the extension can access your browsing activity.
114 The reason for the warning is that
115 although the
<code>chrome.tabs
</code> API
116 might be used only to open new tabs,
117 it can also be used to see the URL that's associated
118 with every newly opened tab
119 (using their $(ref:tabs.Tab) objects).
124 The following table lists the warning messages
126 along with the manifest entries
133 <th> Warning message
</th>
134 <th> Manifest entry that caused it
</th>
138 <td style=
"font-weight:bold">
139 <!-- IDS_EXTENSION_PROMPT_WARNING_FULL_ACCESS -->
140 Read and modify all your data on your computer and the websites you visit
146 The
"plugins" permission is required by
147 <a href=
"npapi">NPAPI plugins
</a>.
152 <td style=
"font-weight:bold">
153 <!-- IDS_EXTENSION_PROMPT_WARNING_BOOKMARKS -->
154 Read and modify your bookmarks
157 "bookmarks" permission
160 The
"bookmarks" permission is required by the
161 <a href=
"bookmarks"><code>chrome.bookmarks
</code></a> module.
166 <td style=
"font-weight:bold">
167 <!-- IDS_EXTENSION_PROMPT_WARNING_BROWSING_HISTORY -->
168 Read and modify your browsing history
171 <!-- HasEffectiveBrowsingHistoryPermission -->
172 Any of the following:
174 <li> "history" permission
</li>
175 <li> "topSites" permission
</li>
180 The
"history" permission is required by
181 <a href=
"history"><code>chrome.history
</code></a>.
184 The
"topSites" permission is required by
185 <a href=
"topSites"><code>chrome.topSites
</code></a>.
191 <td style=
"font-weight:bold">
192 <!-- IDS_EXTENSION_PROMPT_WARNING_TABS -->
193 Access your browsing activity
196 <!-- HasEffectiveBrowsingHistoryPermission -->
197 Any of the following:
199 <li> "tabs" permission
</li>
200 <li> "webNavigation" permission
</li>
205 The
"tabs" permission is required by the
206 <a href=
"tabs"><code>chrome.tabs
</code></a> and
207 <a href=
"windows"><code>chrome.windows
</code></a> modules.
210 The
"webNavigation" permission is required by the
211 <a href=
"webNavigation"><code>chrome.webNavigation
</code></a> module.
217 <td style=
"font-weight:bold">
218 <!-- IDS_EXTENSION_PROMPT_WARNING_CONTENT_SETTINGS -->
219 Manipulate settings that specify whether websites can use features such as cookies, JavaScript, plugins, geolocation, microphone, camera etc.
222 <!-- HasEffectiveBrowsingHistoryPermission -->
223 "contentSettings" permission
227 The
"contentSettings" permission is required by
228 <a href=
"contentSettings"><code>chrome.contentSettings
</code></a>.
234 <td style=
"font-weight:bold">
235 <!-- IDS_EXTENSION_PROMPT_WARNING_ALL_HOSTS -->
236 Read and modify all your data on all websites you visit
239 <!-- HasEffectiveAccessToAllHosts() -->
240 Any of the following:
242 <li> "debugger" permission
</li>
243 <li> "pageCapture" permission
</li>
244 <li> "proxy" permission
</li>
245 <li> A match pattern in the
"permissions" field
246 that matches all hosts
</li>
247 <li> A
"content_scripts" field with a
"matches" entry
248 that matches all hosts
</li>
249 <li> "devtools_page" </li>
254 The
"debugger" permission is required by the
255 <a href=
"debugger">debugger
</a> module.
259 The
"proxy" permission is required by the
260 <a href=
"proxy"><code>chrome.proxy
</code></a> module.
264 Any of the following URLs match all hosts:
267 <li> <code>http://*/*
</code> </li>
268 <li> <code>https://*/*
</code> </li>
269 <li> <code>*://*/*
</code> </li>
270 <li> <code><all_urls
></code> </li>
272 <strong>Note that you may be able to avoid declaring all host permissions using the
<code><a href=
"activeTab">activeTab
</a></code> permission.
</strong>
276 <td style=
"font-weight:bold">
277 <!-- IDS_EXTENSION_PROMPT_WARNING_?_HOST -->
278 <!-- IDS_EXTENSION_PROMPT_WARNING_4_OR_MORE_HOSTS -->
279 Read and modify your data on
<em>{list of websites}
</em>
282 A match pattern in the
"permissions" field
283 that specifies one or more hosts,
288 Up to
3 sites are listed by name.
289 Subdomains aren't treated specially.
290 For example,
<code>a.com
</code> and
<code>b.a.com
</code>
291 are listed as different sites.
296 the user sees a permission warning
297 if the extension adds or changes sites.
298 For example, going from
<code>a.com,b.com
</code>
299 to
<code>a.com,b.com,c.com
</code>
301 Going from
<code>b.a.com
</code>
302 to
<code>a.com
</code>,
304 also triggers a warning.
310 <td style=
"font-weight:bold">
311 <!-- IDS_EXTENSION_PROMPT_WARNING_MANAGEMENT -->
312 Manage your apps, extensions, and themes
315 "management" permission
318 The
"management" permission is required by the
319 <a href=
"management"><code>chrome.management
</code></a> module.
324 <td style=
"font-weight:bold">
325 <!-- IDS_EXTENSION_PROMPT_WARNING_MDNS -->
326 Discover devices on your local network
332 The
"mdns" permission is required by the
333 <a href=
"mdns"><code>chrome.mdns
</code></a> module.
338 <td style=
"font-weight:bold">
339 <!-- IDS_EXTENSION_PROMPT_WARNING_GEOLOCATION -->
340 Detect your physical location
343 "geolocation" permission
346 Allows the extension to use the proposed HTML5
347 <a href=
"http://dev.w3.org/geo/api/spec-source.html">geolocation API
</a>
348 without prompting the user for permission.
353 <td style=
"font-weight:bold">
354 <!-- IDS_EXTENSION_PROMPT_WARNING_CLIPBOARD-->
355 Access data you copy and paste
358 "clipboardRead" permission
361 Allows the extension to use the following editing commands with
362 <code>document.execCommand()
</code>:
364 <li> <code>"copy"</code> </li>
365 <li> <code>"cut"</code> </li>
371 <td style=
"font-weight:bold">
372 <!-- IDS_EXTENSION_PROMPT_WARNING_PRIVACY-->
373 Manipulate privacy-related settings
379 The
"privacy" permission is required by the
380 <a href=
"privacy"><code>chrome.privacy
</code></a> module.
385 <td style=
"font-weight:bold">
386 <!-- IDS_EXTENSION_PROMPT_WARNING_SIGNED_IN_DEVICES-->
387 Access the list of your signed-in devices
390 "signedInDevices" permission
393 The
"signedInDevices" permission is required by the
394 <a href=
"signedInDevices"><code>chrome.signedInDevices
</code></a>
400 <td style=
"font-weight:bold">
401 <!-- IDS_EXTENSION_PROMPT_WARNING_TTS_ENGINE-->
402 Access all text spoken using synthesized speech
405 "ttsEngine" permission
408 The
"ttsEngine" permission is required by the
409 <a href=
"ttsEngine"><code>chrome.ttsEngine
</code></a> module.
416 <h2 id=
"nowarning"> Permissions that don't cause warnings
</h2>
419 The following permissions don't result in a warning:
425 <li>"app.window.alwaysOnTop"</li>
426 <li>"app.window.fullscreen"</li>
427 <li>"app.window.fullscreen.overrideEsc"</li>
428 <li>"app.window.shape"</li>
430 <li>"browsingData"</li>
431 <li>"chrome://favicon/"</li>
432 <li>"clipboardWrite"</li>
433 <li>"contextMenus"</li>
435 <li>"experimental"</li>
437 <li>"notifications"</li>
439 <li>"pointerLock"</li>
442 <li>"unlimitedStorage"</li>
443 <li>"webRequest"</li>
444 <li>"webRequestBlocking"</li>
447 <h2 id=
"test"> Testing permission warnings
</h2>
450 If you'd like to see exactly which warnings your users will get,
451 <a href=
"packaging">package your extension
</a>
452 into a
<code>.crx
</code> file,
457 To see the warnings users will get when your extension is autoupdated,
458 you can go to a little more trouble
459 and set up an autoupdate server.
460 To do this, first create an update manifest
461 and point to it from your extension,
462 using the
"update_url" key
463 (see
<a href=
"autoupdate">Autoupdating
</a>).
464 Next,
<a href=
"packaging">package the extension
</a>
465 into a new
<code>.crx
</code> file,
466 and install the app from this
<code>.crx
</code> file.
467 Now, change the extension's manifest to contain the new permissions,
468 and
<a href=
"packaging#update">repackage the extension
</a>.
469 Finally, update the extension
470 (and all other extensions that have outstanding updates)
471 by clicking the
<b>chrome://extensions
</b> page's
472 <b>Update extensions now
</b> button.
475 <h2 id=
"api">API
</h2>
478 You can get a list of permission warnings for any manifest with
479 $(ref:management.getPermissionWarningsByManifest).