1 // Copyright 2014 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.
5 #ifndef CHROME_BROWSER_CHROMEOS_DRIVE_DIRECTORY_LOADER_H_
6 #define CHROME_BROWSER_CHROMEOS_DRIVE_DIRECTORY_LOADER_H_
13 #include "base/callback.h"
14 #include "base/memory/ref_counted.h"
15 #include "base/memory/scoped_ptr.h"
16 #include "base/memory/scoped_vector.h"
17 #include "base/observer_list.h"
18 #include "base/threading/thread_checker.h"
19 #include "chrome/browser/chromeos/drive/file_errors.h"
20 #include "chrome/browser/chromeos/drive/file_system_interface.h"
21 #include "google_apis/drive/drive_api_error_codes.h"
22 #include "google_apis/drive/drive_common_callbacks.h"
25 class SequencedTaskRunner
;
28 namespace google_apis
{
30 } // namespace google_apis
40 class AboutResourceLoader
;
42 class ChangeListLoaderObserver
;
43 class DirectoryFetchInfo
;
44 class LoaderController
;
45 class ResourceMetadata
;
47 // DirectoryLoader is used to load directory contents.
48 class DirectoryLoader
{
50 DirectoryLoader(EventLogger
* logger
,
51 base::SequencedTaskRunner
* blocking_task_runner
,
52 ResourceMetadata
* resource_metadata
,
53 JobScheduler
* scheduler
,
54 AboutResourceLoader
* about_resource_loader
,
55 LoaderController
* apply_task_controller
);
58 // Adds and removes the observer.
59 void AddObserver(ChangeListLoaderObserver
* observer
);
60 void RemoveObserver(ChangeListLoaderObserver
* observer
);
62 // Reads the directory contents.
63 // |entries_callback| can be null.
64 // |completion_callback| must not be null.
65 void ReadDirectory(const base::FilePath
& directory_path
,
66 const ReadDirectoryEntriesCallback
& entries_callback
,
67 const FileOperationCallback
& completion_callback
);
71 struct ReadDirectoryCallbackState
;
73 // Part of ReadDirectory().
74 void ReadDirectoryAfterGetEntry(
75 const base::FilePath
& directory_path
,
76 const ReadDirectoryEntriesCallback
& entries_callback
,
77 const FileOperationCallback
& completion_callback
,
78 bool should_try_loading_parent
,
79 const ResourceEntry
* entry
,
81 void ReadDirectoryAfterLoadParent(
82 const base::FilePath
& directory_path
,
83 const ReadDirectoryEntriesCallback
& entries_callback
,
84 const FileOperationCallback
& completion_callback
,
86 void ReadDirectoryAfterGetAboutResource(
87 const std::string
& local_id
,
88 google_apis::DriveApiErrorCode status
,
89 scoped_ptr
<google_apis::AboutResource
> about_resource
);
90 void ReadDirectoryAfterCheckLocalState(
91 scoped_ptr
<google_apis::AboutResource
> about_resource
,
92 const std::string
& local_id
,
93 const ResourceEntry
* entry
,
94 const int64
* local_changestamp
,
97 // Part of ReadDirectory().
98 // This function should be called when the directory load is complete.
99 // Flushes the callbacks waiting for the directory to be loaded.
100 void OnDirectoryLoadComplete(const std::string
& local_id
, FileError error
);
101 void OnDirectoryLoadCompleteAfterRead(const std::string
& local_id
,
102 const ResourceEntryVector
* entries
,
105 // Sends |entries| to the callbacks.
106 void SendEntries(const std::string
& local_id
,
107 const ResourceEntryVector
& entries
);
109 // ================= Implementation for directory loading =================
110 // Loads the directory contents from server, and updates the local metadata.
111 // Runs |callback| when it is finished.
112 void LoadDirectoryFromServer(const DirectoryFetchInfo
& directory_fetch_info
);
114 // Part of LoadDirectoryFromServer() for a normal directory.
115 void LoadDirectoryFromServerAfterLoad(
116 const DirectoryFetchInfo
& directory_fetch_info
,
117 FeedFetcher
* fetcher
,
120 // Part of LoadDirectoryFromServer().
121 void LoadDirectoryFromServerAfterUpdateChangestamp(
122 const DirectoryFetchInfo
& directory_fetch_info
,
123 const base::FilePath
* directory_path
,
126 EventLogger
* logger_
; // Not owned.
127 scoped_refptr
<base::SequencedTaskRunner
> blocking_task_runner_
;
128 ResourceMetadata
* resource_metadata_
; // Not owned.
129 JobScheduler
* scheduler_
; // Not owned.
130 AboutResourceLoader
* about_resource_loader_
; // Not owned.
131 LoaderController
* loader_controller_
; // Not owned.
132 base::ObserverList
<ChangeListLoaderObserver
> observers_
;
133 typedef std::map
<std::string
, std::vector
<ReadDirectoryCallbackState
> >
135 LoadCallbackMap pending_load_callback_
;
137 // Set of the running feed fetcher for the fast fetch.
138 std::set
<FeedFetcher
*> fast_fetch_feed_fetcher_set_
;
140 base::ThreadChecker thread_checker_
;
142 // Note: This should remain the last member so it'll be destroyed and
143 // invalidate its weak pointers before any other members are destroyed.
144 base::WeakPtrFactory
<DirectoryLoader
> weak_ptr_factory_
;
145 DISALLOW_COPY_AND_ASSIGN(DirectoryLoader
);
148 } // namespace internal
151 #endif // CHROME_BROWSER_CHROMEOS_DRIVE_DIRECTORY_LOADER_H_