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.syncFileSystem</code> API to save and synchronize data 6 // on Google Drive. This API is NOT for accessing arbitrary user docs stored in 7 // Google Drive. It provides app-specific syncable storage for offline and 8 // caching usage so that the same data can be available across different 9 // clients. Read <a href="app_storage.html">Manage Data</a> for more on using 10 // this API. 11 namespace syncFileSystem { 12 enum SyncAction { 13 added, updated, deleted 14 }; 15 16 enum ServiceStatus { 17 // The sync service is being initialized (e.g. restoring data from the 18 // database, checking connectivity and authenticating to the service etc). 19 initializing, 20 21 // The sync service is up and running. 22 running, 23 24 // The sync service is not synchronizing files because the remote service 25 // needs to be authenticated by the user to proceed. 26 authentication_required, 27 28 // The sync service is not synchronizing files because the remote service 29 // is (temporarily) unavailable due to some recoverable errors, e.g. 30 // network is offline, the remote service is down or not 31 // reachable etc. More details should be given by |description| parameter 32 // in OnServiceInfoUpdated (which could contain service-specific details). 33 temporary_unavailable, 34 35 // The sync service is disabled and the content will never sync. 36 // (E.g. this could happen when the user has no account on 37 // the remote service or the sync service has had an unrecoverable 38 // error.) 39 disabled 40 }; 41 42 enum FileStatus { 43 // Not conflicting and has no pending local changes. 44 synced, 45 46 // Has one or more pending local changes that haven't been synchronized. 47 pending, 48 49 // File conflicts with remote version and must be resolved manually. 50 conflicting 51 }; 52 53 enum SyncDirection { 54 local_to_remote, remote_to_local 55 }; 56 57 enum ConflictResolutionPolicy { 58 last_write_win, manual 59 }; 60 61 dictionary FileInfo { 62 // <code>fileEntry</code> for the target file whose status has changed. 63 // Contains name and path information of synchronized file. 64 // On file deletion, 65 // <code>fileEntry</code> information will still be available 66 // but file will no longer exist. 67 [instanceOf=Entry] object fileEntry; 68 69 // Resulting file status after $(ref:onFileStatusChanged) event. 70 // The status value can be <code>'synced'</code>, 71 // <code>'pending'</code> or <code>'conflicting'</code>. 72 FileStatus status; 73 74 // Sync action taken to fire $(ref:onFileStatusChanged) event. 75 // The action value can be 76 // <code>'added'</code>, <code>'updated'</code> or <code>'deleted'</code>. 77 // Only applies if status is <code>'synced'</code>. 78 SyncAction? action; 79 80 // Sync direction for the $(ref:onFileStatusChanged) event. 81 // Sync direction value can be 82 // <code>'local_to_remote'</code> or <code>'remote_to_local'</code>. 83 // Only applies if status is <code>'synced'</code>. 84 SyncDirection? direction; 85 }; 86 87 dictionary FileStatusInfo { 88 // One of the Entry's originally given to getFileStatuses. 89 [instanceOf=Entry] object fileEntry; 90 91 // The status value can be <code>'synced'</code>, 92 // <code>'pending'</code> or <code>'conflicting'</code>. 93 FileStatus status; 94 95 // Optional error that is only returned if there was a problem retrieving 96 // the FileStatus for the given file. 97 DOMString? error; 98 }; 99 100 dictionary StorageInfo { 101 long usageBytes; 102 long quotaBytes; 103 }; 104 105 dictionary ServiceInfo { 106 ServiceStatus state; 107 DOMString description; 108 }; 109 110 // A callback type for requestFileSystem. 111 callback GetFileSystemCallback = 112 void ([instanceOf=DOMFileSystem] object fileSystem); 113 114 // A callback type for getUsageAndQuota. 115 callback QuotaAndUsageCallback = void (StorageInfo info); 116 117 // Returns true if operation was successful. 118 callback DeleteFileSystemCallback = void (boolean result); 119 120 // A callback type for getFileStatus. 121 callback GetFileStatusCallback = void (FileStatus status); 122 123 // A callback type for getFileStatuses. 124 callback GetFileStatusesCallback = void (FileStatusInfo[] status); 125 126 // A callback type for getServiceStatus. 127 callback GetServiceStatusCallback = void (ServiceStatus status); 128 129 // A callback type for getConflictResolutionPolicy. 130 callback GetConflictResolutionPolicyCallback = 131 void (ConflictResolutionPolicy policy); 132 133 // A generic result callback to indicate success or failure. 134 callback ResultCallback = void (); 135 136 interface Functions { 137 // Returns a syncable filesystem backed by Google Drive. 138 // The returned <code>DOMFileSystem</code> instance can be operated on 139 // in the same way as the Temporary and Persistant file systems (see 140 // <a href="http://www.w3.org/TR/file-system-api/">http://www.w3.org/TR/file-system-api/</a>), 141 // except that the filesystem object returned for Sync FileSystem does 142 // <b>NOT</b> support directory operations (yet). You can get a list 143 // of file entries by reading the root directory (by 144 // <a href="http://www.w3.org/TR/file-system-api/#widl-DirectoryEntry-createReader-DirectoryReader">creating a new DirectoryReader</a>), 145 // but cannot create a new directory in it. 146 // 147 // Calling this multiple times from 148 // the same app will return the same handle to the same file system. 149 // 150 // Note this call can fail. For example, if the user is not signed in to 151 // Chrome or if there is no network operation. To handle these errors it is 152 // important chrome.runtime.lastError is checked in the callback. 153 static void requestFileSystem(GetFileSystemCallback callback); 154 155 // Sets the default conflict resolution policy 156 // for the <code>'syncable'</code> file storage for the app. 157 // By default it is set to <code>'last_write_win'</code>. 158 // When conflict resolution policy is set to <code>'last_write_win'</code> 159 // conflicts for existing files are automatically resolved next time 160 // the file is updated. 161 // |callback| can be optionally given to know if the request has 162 // succeeded or not. 163 static void setConflictResolutionPolicy( 164 ConflictResolutionPolicy policy, 165 optional ResultCallback callback); 166 167 // Gets the current conflict resolution policy. 168 static void getConflictResolutionPolicy( 169 GetConflictResolutionPolicyCallback callback); 170 171 // Returns the current usage and quota in bytes 172 // for the <code>'syncable'</code> file storage for the app. 173 static void getUsageAndQuota([instanceOf=DOMFileSystem] object fileSystem, 174 QuotaAndUsageCallback callback); 175 176 // Returns the $(ref:FileStatus) for the given <code>fileEntry</code>. 177 // The status value can be <code>'synced'</code>, 178 // <code>'pending'</code> or <code>'conflicting'</code>. 179 // Note that <code>'conflicting'</code> state only happens when 180 // the service's conflict resolution policy is set to <code>'manual'</code>. 181 static void getFileStatus([instanceOf=Entry] object fileEntry, 182 GetFileStatusCallback callback); 183 184 // Returns each $(ref:FileStatus) for the given <code>fileEntry</code> array. 185 // Typically called with the result from dirReader.readEntries(). 186 static void getFileStatuses(object[] fileEntries, 187 GetFileStatusesCallback callback); 188 189 // Returns the current sync backend status. 190 static void getServiceStatus(GetServiceStatusCallback callback); 191 }; 192 193 interface Events { 194 // Fired when an error or other status change has happened in the 195 // sync backend (for example, when the sync is temporarily disabled due to 196 // network or authentication error). 197 static void onServiceStatusChanged(ServiceInfo detail); 198 199 // Fired when a file has been updated by the background sync service. 200 static void onFileStatusChanged(FileInfo detail); 201 }; 202 203 }; 204