Roll src/third_party/WebKit d9c6159:8139f33 (svn 201974:201975)
[chromium-blink-merge.git] / chrome / common / extensions / api / file_browser_handler.json
blob0012ac7cf886d9efba0a77222956faf5d9f5e678
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":"fileBrowserHandler",
8     "description": "Use the <code>chrome.fileBrowserHandler</code> API to extend the Chrome OS file browser. For example, you can use this API to enable users to upload files to your website.",
9     "types": [
10       {
11         "id": "FileHandlerExecuteEventDetails",
12         "type": "object",
13         "description": "Event details payload for fileBrowserHandler.onExecute event.",
14         "properties": {
15           "entries": {
16             "type": "array",
17             "items": { "type": "any" },
18             "description": "Array of Entry instances representing files that are targets of this action (selected in ChromeOS file browser)."
19           },
20           "tab_id" : {
21             "type": "integer",
22             "optional": true,
23             "description": "The ID of the tab that raised this event. Tab IDs are unique within a browser session."
24           }
25         }
26       }
27     ],
29     "events": [
30       {
31         "name": "onExecute",
32         "type": "function",
33         "description": "Fired when file system action is executed from ChromeOS file browser.",
34         "parameters": [
35           {
36             "name": "id",
37             "type": "string",
38             "description": "File browser action id as specified in the listener component's manifest."
39           },
40           {
41             "name": "details",
42             "$ref": "FileHandlerExecuteEventDetails",
43             "description": "File handler execute event details."
44           }
45         ]
46       }
47     ],
49     "functions": [
50       {
51         "name": "selectFile",
52         "type": "function",
53         "description": "Prompts user to select file path under which file should be saved. When the file is selected, file access permission required to use the file (read, write and create) are granted to the caller. The file will not actually get created during the function call, so function caller must ensure its existence before using it. The function has to be invoked with a user gesture.",
54         "parameters": [
55           {
56             "name": "selectionParams",
57             "type": "object",
58             "description": "Parameters that will be used while selecting the file.",
59             "properties": {
60               "suggestedName": {
61                   "type": "string",
62                   "description": "Suggested name for the file."
63               },
64               "allowedFileExtensions": {
65                   "type": "array",
66                   "items": { "type": "string" },
67                   "optional": true,
68                   "description": "List of file extensions that the selected file can have. The list is also used to specify what files to be shown in the select file dialog. Files with the listed extensions are only shown in the dialog. Extensions should not include the leading '.'. Example: ['jpg', 'png']"
69               }
70             }
71           },
72           {
73             "name": "callback",
74             "type": "function",
75             "description": "Function called upon completion.",
76             "parameters": [
77               {
78                 "name": "result",
79                 "description": "Result of the method.",
80                 "type": "object",
81                 "properties": {
82                   "success": {
83                     "type": "boolean",
84                     "description": "Whether the file has been selected."
85                   },
86                   "entry": {
87                     "type": "object",
88                     "constructor": "Entry",
89                     "additionalProperties": { "type": "any" },
90                     "optional": true,
91                     "description": "Selected file entry. It will be null if a file hasn't been selected."
92                   }
93                 }
94               }
95             ]
96           }
97         ]
98       }
99     ]
100   }