Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / chrome / common / extensions / docs / templates / json / whats_new.json
blob4975419e8b50829f96ec147e52a089fa4137235e
2     "backgroundpages.to-be-non-persistent": {
3         "type": "additionsToExistingApis",
4         "description": "Background pages can optionally be non-persistent, using a feature we call <code>event pages</code>. Event pages run only while they're being used, and will unload when idle to save resources.",
5         "version": 22
6     },
7     "chromeSetting.set-regular-only-scope": {
8         "type": "additionsToExistingApis",
9         "description": "The types.ChromeSetting.set method now has a <code>regular_only</code> scope.",
10         "version": 21
11     },
12     "browsingData.RemovalOptions.set-originTypes-property": {
13         "type": "additionsToExistingApis",
14         "description": "The browsingData.RemovalOptions now has an <code>originTypes</code> property.",
15         "version": 21
16     },
17     "management.uninstall.set-showConfirmDialog": {
18         "type": "additionsToExistingApis",
19         "description": "The management.uninstall method now has a <code>showConfirmDialog</code> parameter.",
20         "version": 21
21     },
22     "contextMenus.create.set-unique-IDs": {
23         "type": "additionsToExistingApis",
24         "description": "The contextMenus.create method now allows you to specify unique IDs for each item. This is intended to be used with the new <code>contextMenus.onClicked</code> event, to distinguish the clicked item.",
25         "version": 21
26     },
27     "browserAction.setIcon-and-pageAction.setIcon": {
28         "type": "additionsToExistingApis",
29         "description": "The browserAction.setIcon and pageAction.setIcon methods now accept optional callbacks.",
30         "version": 21
31     },
32     "privacy.websites.has-protectedContentEnabled-property": {
33         "type": "additionsToExistingApis",
34         "description": "The privacy.websites namespace now has a <code>protectedContentEnabled</code> property.",
35         "version": 21
36     },
37     "tabs.move.index.accept--1": {
38         "type": "additionsToExistingApis",
39         "description": "The <code>index</code> parameter to the tabs.move method now accepts -1 to indicate that the tab should be placed at the end.",
40         "version": 21
41     },
42     "tabs.highlight.windowId.be-optional": {
43         "type": "additionsToExistingApis",
44         "description": "The <code>windowId</code> parameter to the tabs.highlight method is now optional.",
45         "version": 21
46     },    
47     "manifest-v1-deprecated": {
48         "type": "manifestChanges",
49         "description": "Manifest version 1 was deprecated in Chrome 18 and will be phased out according to the Manifest version 1 support",
50         "version": 20
51     },
52     "chrome.contextMenus.create-and-update-has-enabled-parameter": {
53         "type": "additionsToExistingApis",
54         "description": "The chrome.contextMenus contextMenus.create and contextMenus.update methods now have an <code>enabled</code> parameter.",
55         "version": 20
56     },
57     " privacy.services.has-spellingServiceEnabled-setting": {
58         "type": "additionsToExistingApis",
59         "description": "The privacy API's privacy.services object now has a <code>spellingServiceEnabled</code> setting.",
60         "version": 20
61     },
62     "chrome.tabs.executeScript-and-insertCSS-has-runAt-parameter": {
63         "type": "additionsToExistingApis",
64         "description": "The chrome.tabs tabs.executeScript and tabs.insertCSS now accept a runAt parameter.",
65         "version": 20
66     },
67     "sendRequest.deprecated-for-runtime-and-sendMessage": {
68         "type": "additionsToExistingApis",
69         "description": "The <code>sendRequest()</code> method has been deprecated in favor of the <code>sendMessage()</code> method for both the runtime.sendMessage and tabs.sendMessage.",
70         "version": 20
71     },
72     "window.window.support-fullscreen-state": {
73         "type": "additionsToExistingApis",
74         "description": "The window API's windows.Window object now has an <code>alwaysOnTop</code> property and supports the fullscreen state.",
75         "version": 19
76     },
77     "chrome.tabs.query.has-currentWindow-and-lastFocusedWindow-parameter": {
78         "type": "additionsToExistingApis",
79         "description": "The <code>chrome.tabs</code> tabs.query method now has the <code>currentWindow</code> and <code>lastFocusedWindow</code> parameters.",
80         "version": 19
81     },
82     "browser.action.api.has-new-getter-fucntions": {
83         "type": "additionsToExistingApis",
84         "description": "The browser action API has the following new getter functions: browserAction.getTitle, browserAction.getBadgeText, browserAction.getBadgeBackgroundColor, and browserAction.getPopup.",
85         "version": 19
86     },
87     "page.action.has-new-getter-functions": {
88         "type": "additionsToExistingApis",
89         "description": "The page action API has the following new getter functions: pageAction.getTitle and pageAction.getPopup.",
90         "version": 19
91     },
92     "chrome.tabs.create-update-methods-has-openerTabId-parameter": {
93         "type": "additionsToExistingApis",
94         "description": "The chrome.tabs tabs.create and tabs.update methods now have an <code>openerTabId</code> parameter",
95         "version": 18
96     },
97     "new-manifest-version-field-specifies-the-version": {
98         "type": "manifestChanges",
99         "description": "The new manifest version field specifies the version of the manifest that your package requires. As of Chrome 18, you should use manifest version 2.",
100         "version": 18
101     },
102     "new-CSP-field-define-extensions-policies": {
103         "type": "manifestChanges",
104         "description": "The new Content Security Policy (CSP) field is used to define an extension's policies towards the types of content that can be loaded and executed by the extension.",
105         "version": 18
106     },
107     "background-pages-includes-scripts-property": {
108         "type": "manifestChanges",
109         "description": "Most background pages only include a list of script files. For these background pages, you can use the new background.scripts property and Chrome will generate a background page for you.",
110         "version": 18
111     },
112     "new-web-accessible-resources-field": {
113         "type": "manifestChanges",
114         "description": "The new web_accessible_resources field specifies the paths of packaged resources that are expected to be usable in the context of a web page.",
115         "version": 18
116     },
117     "permission-be-optional-for-some-apis": {
118         "type": "manifestChanges",
119         "description": "Permissions can be optional for the content setting API, the web navigation API, and the new web request API.",
120         "version": 17
121     },
122     "management.ExtensionInfo.object.has-disabledReason-property": {
123         "type": "additionsToExistingApis",
124         "description": "The management API's management.ExtensionInfo object now has a <code>disabledReason</code> property.",
125         "version": 17
126     },
127     "omnibox.api.works-in-split-incognito-mode": {
128         "type": "additionsToExistingApis",
129         "description": "The omnibox API now works in split incognito mode.",
130         "version": 17
131     },
132     "new-requirements-field-declare-extension-requirements": {
133         "type": "manifestChanges",
134         "description": "The new requirements field allows you to declare extension requirements up front. For example, you can use this field to specify that your app requires 3D graphics support in order to use features such as CSS 3D Tranforms or WebGL.",
135         "version": 16
136     },
137     "tabs.query.gets-all-tabs": {
138         "type": "additionsToExistingApis",
139         "description": "The new tabs.query method gets all tabs that have the specified properties or all tabs if no properties are specified.",
140         "version": 16
141     },
142     "tabs.reload.preserve-local-cache": {
143         "type": "additionsToExistingApis",
144         "description": "The new tabs.reload method reloads a tab and includes the option to preserve the local cache of the reloaded tab.",
145         "version": 16
146     },
147     "management.ExtensionInfo.has-updateURL-property": {
148         "type": "additionsToExistingApis",
149         "description": "The management API's management.ExtensionInfo object now has an <code>updateURL</code> property.",
150         "version": 16
151     },
152     "external_extensions.json.limit-supported-locals": {
153         "type": "additionsToExistingApis",
154         "description": "You can now limit the supported locales for an external extension by adding the <code>supported_locales</code> attribute to the <code>external_extensions.json</code>.",
155         "version": 16
156     },
157     "getAllInWindow-getSelected.deprecated": {
158         "type": "additionsToExistingApis",
159         "description": "The methods <code>getAllInWindow()</code> and <code>getSelected()</code> have been deprecated. To get details about all tabs in the specified window, use tabs.query with the argument {'windowId': windowId}. To get the tab that is selected in the specified window, use <code>chrome.tabs.query()</code> with the argument <code>{'active': true}</code>.",
160         "version": 16
161     },
162     "tabs.upate-doesnot-need-tabId": {
163         "type": "additionsToExistingApis",
164         "description": "You are no longer required to specify the <code>tabId</code> for the tabs.update method. When not provided, the tabId defaults to the selected tab of the current window.",
165         "version": 16
166     },
167     "external-files-be-owned-by-users-in-wheel-group": {
168         "type": "additionsToExistingApis",
169         "description": "External extension files on Mac OS can now be owned by users within a wheel group (or an admin group).",
170         "version": 16
171     },
172     "experimental-permission-no-longer-required-for-panel-type": {
173         "type": "additionsToExistingApis",
174         "description": "The experimental permission is no longer required for the panel type. By default, the panel type creates a popup unless the <code>--enable-panels</code> flag is set.",
175         "version": 16
176     },
177     "offline_enabled.field-specify-without-connection": {
178         "type": "manifestChanges",
179         "description": "The new offline_enabled field lets you specify that your app works well even without an internet connection.",
180         "version": 15
181     },
182     "management.getPermissionWarningsById.retrieve-permission-warning": {
183         "type": "additionsToExistingApis",
184         "description": "You can retrieve permission warnings using the new management API methods management.getPermissionWarningsById and management.getPermissionWarningsByManifest.",
185         "version": 15
186     },
187     "management.ExtensionInfo.has-offlineEnabled": {
188         "type": "additionsToExistingApis",
189         "description": "The management API’s management.ExtensionInfo object has a new field, offlineEnabled.",
190         "version": 15
191     },
192     "internationalize.using-placeholders": {
193         "type": "additionsToExistingApis",
194         "description": "You can now internationalize content script CSS files by using __MSG_messagename__ placeholders.",
195         "version": 15
196     },
197     "tabs.update.callback-passed-null": {
198         "type": "additionsToExistingApis",
199         "description": "The callback for the tabs.update method is passed null instead of the tab details if the extension does not have the tabs permission.",
200         "version": 15
201     },
202     "content_security_policy-prevent-xss-attack": {
203         "type": "manifestChanges",
204         "description": "The new content_security_policy field can help prevent cross-site scripting vulnerabilities in your extension.",
205         "version": 14
206     },
207     "nacl_modules.register-native-client-modules": {
208         "type": "manifestChanges",
209         "description": "The new nacl_modules field lets you register Native Client modules as content handlers for MIME types.",
210         "version": 14
211     },
212     "context.menu.items-appear-in-documents": {
213         "type": "additionsToExistingApis",
214         "description": "Context menu items can now appear even in documents that have file:// or chrome:// URLs. Previously, they were restricted to documents with http:// or https:// URLs.",
215         "version": 14
216     },
217     "drawAttention-field-specify-that-window": {
218         "type": "additionsToExistingApis",
219         "description": "An optional drawAttention field in windows.update's updateInfo object lets you specify that the window should entice the user to change focus to it.",
220         "version": 14
221     },
222     "bookmarks.getSubTree-retrieve-bookmarks-hierarchy": {
223         "type": "additionsToExistingApis",
224         "description": "The new bookmarks.getSubTree function lets you retrieve just part of the Bookmarks hierarchy",
225         "version": 14
226     },
227     "tabs.permission.no-longer-required-for-tabs-remove": {
228         "type": "additionsToExistingApis",
229         "description": "The tabs permission is no longer required for tabs.remove and tabs.onRemoved.",
230         "version": 14
231     },
232     "exclude_matches-targets-content-script-precisely": {
233         "type": "manifestChanges",
234         "description": "A new <code>exclude_matches</code> item in the content_scripts field lets you target your content script more precisely. For details, see Match patterns and globs.",
235         "version": 13
236     },
237     "new-clipboardRead-specify-capabilities-for-document.execCommand": {
238         "type": "manifestChanges",
239         "description": "New clipboardRead and clipboardWrite permissions specify capabilities for <code>document.execCommand()</code>.",
240         "version": 13
241     },
242     "content-scripts-make-cross-origin-requests": {
243         "type": "additionsToExistingApis",
244         "description": "Content scripts can now make cross-origin XMLHttpRequests to the same sites that their parent extension can, eliminating the need to relay these requests through a background page.",
245         "version": 13
246     },
247     "use-runat-in-greasemonkey-script": {
248         "type": "additionsToExistingApis",
249         "description": "You can now use <code>@run-at</code> in an imported Greasemonkey script to control when the script is injected. It works the same way as <code>run_at</code> in content scripts.",
250         "version": 13
251     },
252     "two-new-chrome-extension-methods": {
253         "type": "additionsToExistingApis",
254         "description": "Two new <code>chrome.extension</code> methods—extension.isAllowedFileSchemeAccess and extension.isAllowedIncognitoAccess—let you determine whether your extension has increased access, which the user specifies using the extensions management page (chrome://extensions).",
255         "version": 12
256     },
257     "window.create.takes-focused-value": {
258         "type": "additionsToExistingApis",
259         "description": "The windows.create method can now take a <code>focused</code> value. Previously, all new windows had the keyboard focus; now you can create windows without interrupting the user's typing.",
260         "version": 12
261     },
262     "manifest-specifies-experimental-permission": {
263         "type": "additionsToExistingApis",
264         "description": "If the manifest specifies experimental permission, your extension can specify panel as the value of the <code>type</code> field in the windows.create method or the windows.Window type.",
265         "version": 12
266     },
267     "cookies.onChanged.event-has-a-cause-parameter": {
268         "type": "additionsToExistingApis",
269         "description": "The cookies.onChanged event of <code>chrome.cookies</code> now has a <code>cause</code> parameter.",
270         "version": 12
271     },
272     "chrome.contextMenus.create.specifies-frame-value": {
273         "type": "additionsToExistingApis",
274         "description": "The <code>chrome.contextMenus</code> contextMenus.create and contextMenus.update methods now let you specify a context value of frame",
275         "version": 12
276     },
277     "host-permission-for-tabs-operation": {
278         "type": "additionsToExistingApis",
279         "description": "For security reasons, you can no longer call tabs.captureVisibleTab on just any tab. Instead, you now must have host permission for the URL displayed by that tab. To get the previous behavior, specify <code><all_urls></code> for the host permission.",
280         "version": 11
281     },
282     "management.ExtensionInfo.has-homepageUrl-property": {
283         "type": "additionsToExistingApis",
284         "description": "The management API's management.ExtensionInfo object now has a <code>homepageUrl</code> property.",
285         "version": 11
286     },
287     "management.has-homepageUrl-property": {
288         "type": "additionsToExistingApis",
289         "description": "The management API now lets you get the icons of disabled apps and extensions. Also, you can now modify the regular icon's URL to get its disabled equivalent. See management.IconInfo for details.",
290         "version": 11
291     },
292     "cookies.set-take-callbacks": {
293         "type": "additionsToExistingApis",
294         "description": "The cookies API cookies.set and cookies.remove methods can now take callbacks.",
295         "version": 11
296     },
297     "new.background-permission-extends-life-of-chrome": {
298         "type": "manifestChanges",
299         "description": "The new background permission extends the life of Chrome, allowing your extension or app to run even when Chrome has no windows open.",
300         "version": 10
301     },
302     "windows.create.has-tabId-field": {
303         "type": "additionsToExistingApis",
304         "description": "The windows.create method now has a <code>tabId</code> field. You can use it to move a tab or panel into a new window.",
305         "version": 10
306     },
307     "homepage-url-field-specify-extension-homepage": {
308         "type": "manifestChanges",
309         "description": "The homepage_url field lets you specify the extension or app's homepage.",
310         "version": 9
311     },
312     "tabs.Tab.has-pinned-property": {
313         "type": "additionsToExistingApis",
314         "description": "The tabs.Tab object now has a <code>pinned</code> property that's reflected in various <code>chrome.tabs</code> methods. For example, you can tabs.create a pinned tab.",
315         "version": 9
316     },
317     "windows.create.takes-urls": {
318         "type": "additionsToExistingApis",
319         "description": "The windows.create method can now take a list of URLs, letting you create multiple tabs in the new window.",
320         "version": 9
321     },
322     "management.get.specified-apps": {
323         "type": "additionsToExistingApis",
324         "description": "The new management.get method lets you get information about the specified extension or app.",
325         "version": 9
326     },
327     "introduce-split-incognito-mode": {
328         "type": "manifestChanges",
329         "description": "Introduced split incognito mode as the default for installable web apps (also available to extensions).",
330         "version": 7
331     },    
332     "tabs.create-and-update-no-longer-require-tabs-permission": {
333         "type": "manifestChanges",
334         "description": "The tabs API <code>create()</code> and <code>update()</code> methods no longer require the tabs permission, removing one common cause of scary dialogs.",
335         "version": 7
336     },
337     "geolocation-permission-access-users-location": {
338         "type": "manifestChanges",
339         "description": "The geolocation permission gives an extension access to the user's physical location.",
340         "version": 6
341     },
342     "match-patterns-select-all-schemes": {
343         "type": "manifestChanges",
344         "description": "Match patterns can now select all schemes or all URLs.",
345         "version": 6
346     },
347     "access-file-urls-triggers-access-warning": {
348         "type": "manifestChanges",
349         "description": "Access to file:/// URLs no longer triggers the access to your machine security warning, but now requires user opt-in from the extensions management page.",
350         "version": 6
351     },
352     "extension.getViews.return-popup-views": {
353         "type": "additionsToExistingApis",
354         "description": "The extension.getViews method can now return popup views.",
355         "version": 6
356     },
357     "windows.WINDOW_ID_NONE.identifies": {
358         "type": "additionsToExistingApis",
359         "description": "A new windows.WINDOW_ID_NONE constant identifies when focus shifts away from the browser.",
360         "version": 6
361     },
362     "tabs.getCurrent-returns-tab": {
363         "type": "additionsToExistingApis",
364         "description": "The new tabs.getCurrent method returns the tab associated with the currently executing script.",
365         "version": 6
366     }