Merge Chromium + Blink git repositories
[chromium-blink-merge.git] / chrome / common / extensions / api / webstore.json
blobdf5dde78a7fda6bde09ad21fdd2ce975d3dab815
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
3 // found in the LICENSE file.
6   {
7     "namespace": "webstore",
8     "description": "Use the <code>chrome.webstore</code> API to initiate app and extension installations \"inline\" from your site.",
9     "types": [
10       {
11         "id": "InstallStage",
12         "type": "string",
13         "enum": ["installing", "downloading"],
14         "description": "Enum used to indicate the stage of the installation process. 'downloading' indicates that the necessary files are being downloaded, and 'installing' indicates that the files are downloaded and are being actively installed."
15       },
16       {
17         "id": "ErrorCode",
18         "type": "string",
19         "description": "Enum of the possible install results, including error codes sent back in the event that an inline installation has failed.",
20         "enum": [
21           // Keep this list of enums in sync with
22           // chrome/common/extensions/webstore_install_result.h and
23           // chrome/common/extensions/api/webstore/webstore_api_constants.cc!
24           {
25             "description": "An uncommon, unrecognized, or unexpected error. In some cases, the readable error string can provide more information.",
26             "name": "otherError"
27           },
28           {
29             "description": "The operation was aborted as the requestor is no longer alive.",
30             "name": "aborted"
31           },
32           {
33             "description": "An installation of the same extension is in progress.",
34             "name": "installInProgress"
35           },
36           {
37             "description": "The installation is not permitted.",
38             "name": "notPermitted"
39           },
40           {
41             "description": "Invalid Chrome Web Store item ID.",
42             "name": "invalidId"
43           },
44           {
45             "description": "Failed to retrieve extension metadata from the Web Store.",
46             "name": "webstoreRequestError"
47           },
48           {
49             "description": "The extension metadata retrieved from the Web Store was invalid.",
50             "name": "invalidWebstoreResponse"
51           },
52           {
53             "description": "An error occurred while parsing the extension manifest retrieved from the Web Store.",
54             "name": "invalidManifest"
55           },
56           {
57             "description": "Failed to retrieve the extension's icon from the Web Store, or the icon was invalid.",
58             "name": "iconError"
59           },
60           {
61             "description": "The user canceled the operation.",
62             "name": "userCanceled"
63           },
64           {
65             "description": "The extension is blacklisted.",
66             "name": "blacklisted"
67           },
68           {
69             "description": "Unsatisfied dependencies, such as shared modules.",
70             "name": "missingDependencies"
71           },
72           {
73             "description": "Unsatisfied requirements, such as webgl.",
74             "name": "requirementViolations"
75           },
76           {
77             "description": "The extension is blocked by management policies.",
78             "name": "blockedByPolicy"
79           },
80           {
81             "description": "The launch feature is not available.",
82             "name": "launchFeatureDisabled"
83           },
84           {
85             "description": "The launch feature is not supported for the extension type.",
86             "name": "launchUnsupportedExtensionType"
87           },
88           {
89             "description": "A launch of the same extension is in progress.",
90             "name": "launchInProgress"
91           }
92         ]
93       }
94     ],  // types
95     "events": [
96       {
97         "name": "onInstallStageChanged",
98         "description": "Fired when an inline installation enters a new InstallStage. In order to receive notifications about this event, listeners must be registered before the inline installation begins.",
99         "type": "function",
100         "parameters": [
101           {
102             "name": "stage",
103             "$ref": "InstallStage",
104             "description": "The InstallStage that just began."
105           }
106         ]
107       },  // onInstallStageChanged
108       {
109         "name": "onDownloadProgress",
110         "description": "Fired periodically with the download progress of an inline install. In order to receive notifications about this event, listeners must be registered before the inline installation begins.",
111         "type": "function",
112         "parameters": [
113           {
114             "name": "percentDownloaded",
115             "type": "number",
116             "description": "The progress of the download, between 0 and 1. 0 indicates no progress; 1.0 indicates complete."
117           }
118         ]
119       }  // onDownloadProgress
120     ],  // events
121     "functions": [
122       {
123         "name": "install",
124         "allowAmbiguousOptionalArguments": true,
125         "parameters": [
126           {
127             "name": "url",
128             "type": "string",
129             "optional": true,
130             "description": "If you have more than one <code>&lt;link&gt;</code> tag on your page with the <code>chrome-webstore-item</code> relation, you can choose which item you'd like to install by passing in its URL here. If it is omitted, then the first (or only) link will be used. An exception will be thrown if the passed in URL does not exist on the page."
131           },
132           {
133             "name": "successCallback",
134             "type": "function",
135             "optional": true,
136             "parameters": [],
137             "description": "This function is invoked when inline installation successfully completes (after the dialog is shown and the user agrees to add the item to Chrome). You may wish to use this to hide the user interface element that prompted the user to install the app or extension."
138           },
139           {
140             "name": "failureCallback",
141             "type": "function",
142             "optional": true,
143             "parameters": [
144               {
145                 "name": "error",
146                 "type": "string",
147                 "description": "The failure detail. You may wish to inspect or log this for debugging purposes, but you should not rely on specific strings being passed back."
148               },
149               {
150                 "name": "errorCode",
151                 "$ref": "ErrorCode",
152                 "optional": "true",
153                 "description": "The error code from the stable set of possible errors."
154               }
155             ],
156             "description": "This function is invoked when inline installation does not successfully complete. Possible reasons for this include the user canceling the dialog, the linked item not being found in the store, or the install being initiated from a non-verified site."
157           }
158         ]
159       }  // install
160     ]  // functions
161   }  // webstore