Chromium Code Reviews| Index: chrome/browser/chromeos/extensions/file_browser_event_router.cc |
| diff --git a/chrome/browser/chromeos/extensions/file_browser_event_router.cc b/chrome/browser/chromeos/extensions/file_browser_event_router.cc |
| index 4431f9dcaeef1f15f6bef881bbf519510c561d50..45a20773e21f9161d9a854d6306390959337b220 100644 |
| --- a/chrome/browser/chromeos/extensions/file_browser_event_router.cc |
| +++ b/chrome/browser/chromeos/extensions/file_browser_event_router.cc |
| @@ -226,6 +226,44 @@ void FileBrowserEventRouter::RemoveFileWatch( |
| } |
| } |
| +void FileBrowserEventRouter::MountGData( |
| + const base::Callback<void(bool)>& callback) { |
|
satorux1
2012/08/01 20:59:01
add DCHECK(BrowserThread::CurrentlyOn(BrowserThrea
yoshiki
2012/08/01 22:23:39
Done.
|
| + gdata::GDataSystemService* system_service = |
| + gdata::GDataSystemServiceFactory::GetForProfile(profile_); |
| + if (system_service) { |
| + system_service->docs_service()->Authenticate( |
| + base::Bind(&FileBrowserEventRouter::OnGDataAuthentication, |
| + this, |
| + callback)); |
| + } |
| +} |
| + |
| +void FileBrowserEventRouter::OnGDataAuthentication( |
| + const base::Callback<void(bool)>& callback, |
| + gdata::GDataErrorCode error, |
| + const std::string& token) { |
|
satorux1
2012/08/01 20:59:01
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::U
yoshiki
2012/08/01 22:23:39
Done.
|
| + chromeos::MountError error_code; |
| + // For the file manager to work offline, GDATA_NO_CONNECTION is allowed. |
| + if (error == gdata::HTTP_SUCCESS || error == gdata::GDATA_NO_CONNECTION) |
| + error_code = chromeos::MOUNT_ERROR_NONE; |
| + else |
| + error_code = chromeos::MOUNT_ERROR_NOT_AUTHENTICATED; |
| + |
| + // Pass back the gdata mount point path as source path. |
| + const std::string& gdata_path = gdata::util::GetGDataMountPointPathAsString(); |
| + DiskMountManager::MountPointInfo mount_info( |
| + gdata_path, |
| + gdata_path, |
| + chromeos::MOUNT_TYPE_GDATA, |
| + chromeos::disks::MOUNT_CONDITION_NONE); |
| + |
| + // Raise mount event. |
| + MountCompleted(DiskMountManager::MOUNTING, error_code, mount_info); |
| + |
| + if (!callback.is_null()) |
| + callback.Run(true); |
| +} |
| + |
| void FileBrowserEventRouter::HandleRemoteUpdateRequestOnUIThread(bool start) { |
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| @@ -416,6 +454,25 @@ void FileBrowserEventRouter::OnDocumentFeedFetched( |
| NULL, GURL()); |
| } |
| +void FileBrowserEventRouter::OnFileSystemMounted() { |
| + DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| + MountGData(base::Callback<void(bool)>()); // Callback does nothing. |
| +} |
| + |
| +void FileBrowserEventRouter::OnFileSystemUnmounting() { |
| + DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| + |
| + // Raise a MountCompleted event to notify the File Manager. |
| + const std::string& gdata_path = gdata::util::GetGDataMountPointPathAsString(); |
| + DiskMountManager::MountPointInfo mount_info( |
| + gdata_path, |
| + gdata_path, |
| + chromeos::MOUNT_TYPE_GDATA, |
| + chromeos::disks::MOUNT_CONDITION_NONE); |
| + MountCompleted(DiskMountManager::UNMOUNTING, chromeos::MOUNT_ERROR_NONE, |
| + mount_info); |
| +} |
| + |
| void FileBrowserEventRouter::OnAuthenticationFailed() { |
| DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |