Home | History | Annotate | Download | only in api
      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.
      4 
      5 // Use the <code>chrome.fileSystem</code> API to create, read, navigate,
      6 // and write to a sandboxed section of the user's local file system. With this
      7 // API, Chrome Apps can read and write to a user-selected location. For
      8 // example, a text editor app can use the API to read and write local documents.
      9 // All failures are notified via chrome.runtime.lastError.
     10 namespace fileSystem {
     11   dictionary AcceptOption {
     12     // This is the optional text description for this option. If not present,
     13     // a description will be automatically generated; typically containing an
     14     // expanded list of valid extensions (e.g. "text/html" may expand to
     15     // "*.html, *.htm").
     16     DOMString? description;
     17 
     18     // Mime-types to accept, e.g. "image/jpeg" or "audio/*". One of mimeTypes or
     19     // extensions must contain at least one valid element.
     20     DOMString[]? mimeTypes;
     21 
     22     // Extensions to accept, e.g. "jpg", "gif", "crx".
     23     DOMString[]? extensions;
     24   };
     25 
     26   enum ChooseEntryType {
     27 
     28     // Prompts the user to open an existing file and returns a FileEntry on
     29     // success. From Chrome 31 onwards, the FileEntry will be writable if the
     30     // application has the 'write' permission under 'fileSystem'; otherwise, the
     31     // FileEntry will be read-only.
     32     openFile,
     33 
     34     // Prompts the user to open an existing file and returns a writable
     35     // FileEntry on success. Calls using this type will fail with a runtime
     36     // error if the application doesn't have the 'write' permission under
     37     // 'fileSystem'.
     38     openWritableFile,
     39 
     40     // Prompts the user to open an existing file or a new file and returns a
     41     // writable FileEntry on success. Calls using this type will fail with a
     42     // runtime error if the application doesn't have the 'write' permission
     43     // under 'fileSystem'.
     44     saveFile,
     45 
     46     // Prompts the user to open a directory and returns a DirectoryEntry on
     47     // success. Calls using this type will fail with a runtime error if the
     48     // application doesn't have the 'directory' permission under 'fileSystem'.
     49     // If the application has the 'write' permission under 'fileSystem', the
     50     // returned DirectoryEntry will be writable; otherwise it will be read-only.
     51     // New in Chrome 31.
     52     openDirectory
     53   };
     54 
     55   dictionary ChooseEntryOptions {
     56     // Type of the prompt to show. The default is 'openFile'.
     57     ChooseEntryType? type;
     58 
     59     // The suggested file name that will be presented to the user as the
     60     // default name to read or write. This is optional.
     61     DOMString? suggestedName;
     62 
     63     // The optional list of accept options for this file opener. Each option
     64     // will be presented as a unique group to the end-user.
     65     AcceptOption[]? accepts;
     66 
     67     // Whether to accept all file types, in addition to the options specified
     68     // in the accepts argument. The default is true. If the accepts field is
     69     // unset or contains no valid entries, this will always be reset to true.
     70     boolean? acceptsAllTypes;
     71 
     72     // Whether to accept multiple files. This is only supported for openFile and
     73     // openWritableFile. The callback to chooseEntry will be called with a list
     74     // of entries if this is set to true. Otherwise it will be called with a
     75     // single Entry.
     76     boolean? acceptsMultiple;
     77   };
     78   callback GetDisplayPathCallback = void (DOMString displayPath);
     79   callback EntryCallback = void ([instanceOf=Entry] object entry);
     80   callback EntriesCallback = void (
     81       [instanceOf=Entry] optional object entry,
     82       [instanceOf=FileEntry] optional object[] fileEntries);
     83   callback IsWritableCallback = void (boolean isWritable);
     84   callback IsRestorableCallback = void (boolean isRestorable);
     85 
     86   interface Functions {
     87     // Get the display path of an Entry object. The display path is based on
     88     // the full path of the file or directory on the local file system, but may
     89     // be made more readable for display purposes.
     90     static void getDisplayPath([instanceOf=Entry] object entry,
     91                                GetDisplayPathCallback callback);
     92 
     93     // Get a writable Entry from another Entry. This call will fail with a
     94     // runtime error if the application does not have the 'write' permission
     95     // under 'fileSystem'. If entry is a DirectoryEntry, this call will fail if
     96     // the application does not have the 'directory' permission under
     97     // 'fileSystem'.
     98     static void getWritableEntry([instanceOf=Entry] object entry,
     99                                  EntryCallback callback);
    100 
    101     // Gets whether this Entry is writable or not.
    102     static void isWritableEntry([instanceOf=Entry] object entry,
    103                                 IsWritableCallback callback);
    104 
    105     // Ask the user to choose a file or directory.
    106     static void chooseEntry(optional ChooseEntryOptions options,
    107                             EntriesCallback callback);
    108 
    109     // Returns the file entry with the given id if it can be restored. This call
    110     // will fail with a runtime error otherwise. This method is new in Chrome
    111     // 31.
    112     static void restoreEntry(DOMString id, EntryCallback callback);
    113 
    114     // Returns whether the app has permission to restore the entry with the
    115     // given id. This method is new in Chrome 31.
    116     static void isRestorable(DOMString id, IsRestorableCallback callback);
    117 
    118     // Returns an id that can be passed to restoreEntry to regain access to a
    119     // given file entry. Only the 500 most recently used entries are retained,
    120     // where calls to retainEntry and restoreEntry count as use. If the app has
    121     // the 'retainEntries' permission under 'fileSystem', entries are retained
    122     // indefinitely. Otherwise, entries are retained only while the app is
    123     // running and across restarts. This method is new in Chrome 31.
    124     static DOMString retainEntry([instanceOf=Entry] object entry);
    125   };
    126 };
    127