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 #ifndef CHROME_BROWSER_DRIVE_DRIVE_SERVICE_INTERFACE_H_ 6 #define CHROME_BROWSER_DRIVE_DRIVE_SERVICE_INTERFACE_H_ 7 8 #include <string> 9 10 #include "base/time/time.h" 11 #include "google_apis/drive/auth_service_interface.h" 12 #include "google_apis/drive/base_requests.h" 13 #include "google_apis/drive/drive_api_requests.h" 14 #include "google_apis/drive/drive_common_callbacks.h" 15 16 namespace base { 17 class Time; 18 } 19 20 namespace drive { 21 22 // Observer interface for DriveServiceInterface. 23 class DriveServiceObserver { 24 public: 25 // Triggered when the service gets ready to send requests. OnReadyToSendRequests()26 virtual void OnReadyToSendRequests() {} 27 28 // Called when the refresh token was found to be invalid. OnRefreshTokenInvalid()29 virtual void OnRefreshTokenInvalid() {} 30 31 protected: ~DriveServiceObserver()32 virtual ~DriveServiceObserver() {} 33 }; 34 35 // This defines an interface for sharing by DriveService and MockDriveService 36 // so that we can do testing of clients of DriveService. 37 // 38 // All functions must be called on UI thread. DriveService is built on top of 39 // URLFetcher that runs on UI thread. 40 class DriveServiceInterface { 41 public: 42 // Optional parameters for AddNewDirectory(). 43 struct AddNewDirectoryOptions { 44 AddNewDirectoryOptions(); 45 ~AddNewDirectoryOptions(); 46 47 // modified_date of the directory. 48 // Pass the null Time if you are not interested in setting this property. 49 base::Time modified_date; 50 51 // last_viewed_by_me_date of the directory. 52 // Pass the null Time if you are not interested in setting this property. 53 base::Time last_viewed_by_me_date; 54 }; 55 56 // Optional parameters for InitiateUploadNewFile(). 57 struct InitiateUploadNewFileOptions { 58 InitiateUploadNewFileOptions(); 59 ~InitiateUploadNewFileOptions(); 60 61 // modified_date of the file. 62 // Pass the null Time if you are not interested in setting this property. 63 base::Time modified_date; 64 65 // last_viewed_by_me_date of the file. 66 // Pass the null Time if you are not interested in setting this property. 67 base::Time last_viewed_by_me_date; 68 }; 69 70 // Optional parameters for InitiateUploadExistingFile(). 71 struct InitiateUploadExistingFileOptions { 72 InitiateUploadExistingFileOptions(); 73 ~InitiateUploadExistingFileOptions(); 74 75 // Expected ETag of the file. UPLOAD_ERROR_CONFLICT error is generated when 76 // matching fails. 77 // Pass the empty string to disable this behavior. 78 std::string etag; 79 80 // New parent of the file. 81 // Pass the empty string to keep the property unchanged. 82 std::string parent_resource_id; 83 84 // New title of the file. 85 // Pass the empty string to keep the property unchanged. 86 std::string title; 87 88 // New modified_date of the file. 89 // Pass the null Time if you are not interested in setting this property. 90 base::Time modified_date; 91 92 // New last_viewed_by_me_date of the file. 93 // Pass the null Time if you are not interested in setting this property. 94 base::Time last_viewed_by_me_date; 95 }; 96 ~DriveServiceInterface()97 virtual ~DriveServiceInterface() {} 98 99 // Common service: 100 101 // Initializes the documents service with |account_id|. 102 virtual void Initialize(const std::string& account_id) = 0; 103 104 // Adds an observer. 105 virtual void AddObserver(DriveServiceObserver* observer) = 0; 106 107 // Removes an observer. 108 virtual void RemoveObserver(DriveServiceObserver* observer) = 0; 109 110 // True if ready to send requests. 111 virtual bool CanSendRequest() const = 0; 112 113 // Authentication service: 114 115 // True if OAuth2 access token is retrieved and believed to be fresh. 116 virtual bool HasAccessToken() const = 0; 117 118 // Gets the cached OAuth2 access token or if empty, then fetches a new one. 119 virtual void RequestAccessToken( 120 const google_apis::AuthStatusCallback& callback) = 0; 121 122 // True if OAuth2 refresh token is present. 123 virtual bool HasRefreshToken() const = 0; 124 125 // Clears OAuth2 access token. 126 virtual void ClearAccessToken() = 0; 127 128 // Clears OAuth2 refresh token. 129 virtual void ClearRefreshToken() = 0; 130 131 // Document access: 132 133 // Returns the resource id for the root directory. 134 virtual std::string GetRootResourceId() const = 0; 135 136 // Fetches a file list of the account. |callback| will be called upon 137 // completion. 138 // If the list is too long, it may be paged. In such a case, a URL to fetch 139 // remaining results will be included in the returned result. See also 140 // GetRemainingFileList. 141 // 142 // |callback| must not be null. 143 virtual google_apis::CancelCallback GetAllFileList( 144 const google_apis::FileListCallback& callback) = 0; 145 146 // Fetches a file list in the directory with |directory_resource_id|. 147 // |callback| will be called upon completion. 148 // If the list is too long, it may be paged. In such a case, a URL to fetch 149 // remaining results will be included in the returned result. See also 150 // GetRemainingFileList. 151 // 152 // |directory_resource_id| must not be empty. 153 // |callback| must not be null. 154 virtual google_apis::CancelCallback GetFileListInDirectory( 155 const std::string& directory_resource_id, 156 const google_apis::FileListCallback& callback) = 0; 157 158 // Searches the resources for the |search_query| from all the user's 159 // resources. |callback| will be called upon completion. 160 // If the list is too long, it may be paged. In such a case, a URL to fetch 161 // remaining results will be included in the returned result. See also 162 // GetRemainingFileList. 163 // 164 // |search_query| must not be empty. 165 // |callback| must not be null. 166 virtual google_apis::CancelCallback Search( 167 const std::string& search_query, 168 const google_apis::FileListCallback& callback) = 0; 169 170 // Searches the resources with the |title|. 171 // |directory_resource_id| is an optional parameter. If it is empty, 172 // the search target is all the existing resources. Otherwise, it is 173 // the resources directly under the directory with |directory_resource_id|. 174 // If the list is too long, it may be paged. In such a case, a URL to fetch 175 // remaining results will be included in the returned result. See also 176 // GetRemainingFileList. 177 // 178 // |title| must not be empty, and |callback| must not be null. 179 virtual google_apis::CancelCallback SearchByTitle( 180 const std::string& title, 181 const std::string& directory_resource_id, 182 const google_apis::FileListCallback& callback) = 0; 183 184 // Fetches change list since |start_changestamp|. |callback| will be 185 // called upon completion. 186 // If the list is too long, it may be paged. In such a case, a URL to fetch 187 // remaining results will be included in the returned result. See also 188 // GetRemainingChangeList. 189 // 190 // |callback| must not be null. 191 virtual google_apis::CancelCallback GetChangeList( 192 int64 start_changestamp, 193 const google_apis::ChangeListCallback& callback) = 0; 194 195 // The result of GetChangeList() may be paged. 196 // In such a case, a next link to fetch remaining result is returned. 197 // The page token can be used for this method. |callback| will be called upon 198 // completion. 199 // 200 // |next_link| must not be empty. |callback| must not be null. 201 virtual google_apis::CancelCallback GetRemainingChangeList( 202 const GURL& next_link, 203 const google_apis::ChangeListCallback& callback) = 0; 204 205 // The result of GetAllFileList(), GetFileListInDirectory(), Search() 206 // and SearchByTitle() may be paged. In such a case, a next link to fetch 207 // remaining result is returned. The page token can be used for this method. 208 // |callback| will be called upon completion. 209 // 210 // |next_link| must not be empty. |callback| must not be null. 211 virtual google_apis::CancelCallback GetRemainingFileList( 212 const GURL& next_link, 213 const google_apis::FileListCallback& callback) = 0; 214 215 // Fetches single entry metadata from server. The entry's file id equals 216 // |resource_id|. 217 // Upon completion, invokes |callback| with results on the calling thread. 218 // |callback| must not be null. 219 virtual google_apis::CancelCallback GetFileResource( 220 const std::string& resource_id, 221 const google_apis::FileResourceCallback& callback) = 0; 222 223 // Fetches an url for the sharing dialog for a single entry with id 224 // |resource_id|, to be embedded in a webview or an iframe with origin 225 // |embed_origin|. The url is returned via |callback| with results on the 226 // calling thread. |callback| must not be null. 227 virtual google_apis::CancelCallback GetShareUrl( 228 const std::string& resource_id, 229 const GURL& embed_origin, 230 const google_apis::GetShareUrlCallback& callback) = 0; 231 232 // Gets the about resource information from the server. 233 // Upon completion, invokes |callback| with results on the calling thread. 234 // |callback| must not be null. 235 virtual google_apis::CancelCallback GetAboutResource( 236 const google_apis::AboutResourceCallback& callback) = 0; 237 238 // Gets the application information from the server. 239 // Upon completion, invokes |callback| with results on the calling thread. 240 // |callback| must not be null. 241 virtual google_apis::CancelCallback GetAppList( 242 const google_apis::AppListCallback& callback) = 0; 243 244 // Permanently deletes a resource identified by its |resource_id|. 245 // If |etag| is not empty and did not match, the deletion fails with 246 // HTTP_PRECONDITION error. 247 // Upon completion, invokes |callback| with results on the calling thread. 248 // |callback| must not be null. 249 virtual google_apis::CancelCallback DeleteResource( 250 const std::string& resource_id, 251 const std::string& etag, 252 const google_apis::EntryActionCallback& callback) = 0; 253 254 // Trashes a resource identified by its |resource_id|. 255 // Upon completion, invokes |callback| with results on the calling thread. 256 // |callback| must not be null. 257 virtual google_apis::CancelCallback TrashResource( 258 const std::string& resource_id, 259 const google_apis::EntryActionCallback& callback) = 0; 260 261 // Makes a copy of a resource with |resource_id|. 262 // The new resource will be put under a directory with |parent_resource_id|, 263 // and it'll be named |new_title|. 264 // If |last_modified| is not null, the modified date of the resource on the 265 // server will be set to the date. 266 // This request is supported only on DriveAPIService, because GData WAPI 267 // doesn't support the function unfortunately. 268 // Upon completion, invokes |callback| with results on the calling thread. 269 // |callback| must not be null. 270 virtual google_apis::CancelCallback CopyResource( 271 const std::string& resource_id, 272 const std::string& parent_resource_id, 273 const std::string& new_title, 274 const base::Time& last_modified, 275 const google_apis::FileResourceCallback& callback) = 0; 276 277 // Updates a resource with |resource_id| to the directory of 278 // |parent_resource_id| with renaming to |new_title|. 279 // If |last_modified| or |last_accessed| is not null, the modified/accessed 280 // date of the resource on the server will be set to the date. 281 // This request is supported only on DriveAPIService, because GData WAPI 282 // doesn't support the function unfortunately. 283 // Upon completion, invokes |callback| with results on the calling thread. 284 // |callback| must not be null. 285 virtual google_apis::CancelCallback UpdateResource( 286 const std::string& resource_id, 287 const std::string& parent_resource_id, 288 const std::string& new_title, 289 const base::Time& last_modified, 290 const base::Time& last_viewed_by_me, 291 const google_apis::FileResourceCallback& callback) = 0; 292 293 // Adds a resource (document, file, or collection) identified by its 294 // |resource_id| to a collection represented by the |parent_resource_id|. 295 // Upon completion, invokes |callback| with results on the calling thread. 296 // |callback| must not be null. 297 virtual google_apis::CancelCallback AddResourceToDirectory( 298 const std::string& parent_resource_id, 299 const std::string& resource_id, 300 const google_apis::EntryActionCallback& callback) = 0; 301 302 // Removes a resource (document, file, collection) identified by its 303 // |resource_id| from a collection represented by the |parent_resource_id|. 304 // Upon completion, invokes |callback| with results on the calling thread. 305 // |callback| must not be null. 306 virtual google_apis::CancelCallback RemoveResourceFromDirectory( 307 const std::string& parent_resource_id, 308 const std::string& resource_id, 309 const google_apis::EntryActionCallback& callback) = 0; 310 311 // Adds new collection with |directory_title| under parent directory 312 // identified with |parent_resource_id|. |parent_resource_id| can be the 313 // value returned by GetRootResourceId to represent the root directory. 314 // Upon completion, invokes |callback| and passes newly created entry on 315 // the calling thread. 316 // This function cannot be named as "CreateDirectory" as it conflicts with 317 // a macro on Windows. 318 // |callback| must not be null. 319 virtual google_apis::CancelCallback AddNewDirectory( 320 const std::string& parent_resource_id, 321 const std::string& directory_title, 322 const AddNewDirectoryOptions& options, 323 const google_apis::FileResourceCallback& callback) = 0; 324 325 // Downloads a file with |resourced_id|. The downloaded file will 326 // be stored at |local_cache_path| location. Upon completion, invokes 327 // |download_action_callback| with results on the calling thread. 328 // If |get_content_callback| is not empty, 329 // URLFetcherDelegate::OnURLFetchDownloadData will be called, which will in 330 // turn invoke |get_content_callback| on the calling thread. 331 // If |progress_callback| is not empty, it is invoked periodically when 332 // the download made some progress. 333 // 334 // |download_action_callback| must not be null. 335 // |get_content_callback| and |progress_callback| may be null. 336 virtual google_apis::CancelCallback DownloadFile( 337 const base::FilePath& local_cache_path, 338 const std::string& resource_id, 339 const google_apis::DownloadActionCallback& download_action_callback, 340 const google_apis::GetContentCallback& get_content_callback, 341 const google_apis::ProgressCallback& progress_callback) = 0; 342 343 // Initiates uploading of a new document/file. 344 // |content_type| and |content_length| should be the ones of the file to be 345 // uploaded. 346 // |callback| must not be null. 347 virtual google_apis::CancelCallback InitiateUploadNewFile( 348 const std::string& content_type, 349 int64 content_length, 350 const std::string& parent_resource_id, 351 const std::string& title, 352 const InitiateUploadNewFileOptions& options, 353 const google_apis::InitiateUploadCallback& callback) = 0; 354 355 // Initiates uploading of an existing document/file. 356 // |content_type| and |content_length| should be the ones of the file to be 357 // uploaded. 358 // |callback| must not be null. 359 virtual google_apis::CancelCallback InitiateUploadExistingFile( 360 const std::string& content_type, 361 int64 content_length, 362 const std::string& resource_id, 363 const InitiateUploadExistingFileOptions& options, 364 const google_apis::InitiateUploadCallback& callback) = 0; 365 366 // Resumes uploading of a document/file on the calling thread. 367 // |callback| must not be null. |progress_callback| may be null. 368 virtual google_apis::CancelCallback ResumeUpload( 369 const GURL& upload_url, 370 int64 start_position, 371 int64 end_position, 372 int64 content_length, 373 const std::string& content_type, 374 const base::FilePath& local_file_path, 375 const google_apis::drive::UploadRangeCallback& callback, 376 const google_apis::ProgressCallback& progress_callback) = 0; 377 378 // Gets the current status of the uploading to |upload_url| from the server. 379 // |drive_file_path| and |content_length| should be set to the same value 380 // which is used for ResumeUpload. 381 // |callback| must not be null. 382 virtual google_apis::CancelCallback GetUploadStatus( 383 const GURL& upload_url, 384 int64 content_length, 385 const google_apis::drive::UploadRangeCallback& callback) = 0; 386 387 // Authorizes a Drive app with the id |app_id| to open the given file. 388 // Upon completion, invokes |callback| with the link to open the file with 389 // the provided app. |callback| must not be null. 390 virtual google_apis::CancelCallback AuthorizeApp( 391 const std::string& resource_id, 392 const std::string& app_id, 393 const google_apis::AuthorizeAppCallback& callback) = 0; 394 395 // Uninstalls a Drive app with the id |app_id|. |callback| must not be null. 396 virtual google_apis::CancelCallback UninstallApp( 397 const std::string& app_id, 398 const google_apis::EntryActionCallback& callback) = 0; 399 400 // Authorizes the account |email| to access |resource_id| as a |role|. 401 // 402 // |callback| must not be null. 403 virtual google_apis::CancelCallback AddPermission( 404 const std::string& resource_id, 405 const std::string& email, 406 google_apis::drive::PermissionRole role, 407 const google_apis::EntryActionCallback& callback) = 0; 408 }; 409 410 } // namespace drive 411 412 #endif // CHROME_BROWSER_DRIVE_DRIVE_SERVICE_INTERFACE_H_ 413