drive_internals_ui.cc revision f2477e01787aa58f445919b809d89e252beef54f
15821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Copyright (c) 2012 The Chromium Authors. All rights reserved. 25821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Use of this source code is governed by a BSD-style license that can be 35821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// found in the LICENSE file. 45821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 55821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/ui/webui/chromeos/drive_internals_ui.h" 65821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 75821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/bind.h" 85821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/command_line.h" 95821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/file_util.h" 10868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)#include "base/files/file_enumerator.h" 115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/format_macros.h" 125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/memory/scoped_vector.h" 135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/memory/weak_ptr.h" 145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/path_service.h" 152a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "base/prefs/pref_service.h" 16868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)#include "base/strings/stringprintf.h" 175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "base/sys_info.h" 18c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "chrome/browser/chromeos/drive/debug_info_collector.h" 195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/chromeos/drive/drive.pb.h" 2090dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)#include "chrome/browser/chromeos/drive/drive_integration_service.h" 21c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "chrome/browser/chromeos/drive/file_system_interface.h" 22c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "chrome/browser/chromeos/drive/file_system_util.h" 23868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles)#include "chrome/browser/chromeos/drive/job_list.h" 24c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)#include "chrome/browser/chromeos/drive/logging.h" 25eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch#include "chrome/browser/drive/drive_api_util.h" 267d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles)#include "chrome/browser/drive/drive_notification_manager.h" 277d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles)#include "chrome/browser/drive/drive_notification_manager_factory.h" 287d4cd473f85ac64c3747c96c277f9e506a0d2246Torne (Richard Coles)#include "chrome/browser/drive/drive_service_interface.h" 29eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch#include "chrome/browser/drive/drive_switches.h" 30eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch#include "chrome/browser/drive/event_logger.h" 315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/google_apis/auth_service.h" 325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/google_apis/drive_api_parser.h" 335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/google_apis/gdata_errorcode.h" 345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/google_apis/gdata_wapi_parser.h" 352a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "chrome/browser/google_apis/time_util.h" 365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/browser/profiles/profile.h" 375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "chrome/common/pref_names.h" 382a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "chrome/common/url_constants.h" 39b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)#include "chromeos/chromeos_switches.h" 405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/browser/browser_thread.h" 415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/browser/web_ui.h" 422a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)#include "content/public/browser/web_ui_data_source.h" 435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "content/public/browser/web_ui_message_handler.h" 445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)#include "grit/browser_resources.h" 455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)using content::BrowserThread; 475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace chromeos { 495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)namespace { 515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Gets metadata of all files and directories in |root_path| 535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// recursively. Stores the result as a list of dictionaries like: 545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// 558bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles)// [{ path: 'GCache/v1/tmp/<local_id>', 565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// size: 12345, 575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// is_directory: false, 585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// last_modified: '2005-08-09T09:57:00-08:00', 595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// },...] 605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// 615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// The list is sorted by the path. 622a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void GetGCacheContents(const base::FilePath& root_path, 635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::ListValue* gcache_contents, 645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* gcache_summary) { 65b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI)); 66b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(gcache_contents); 67b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(gcache_summary); 68b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Use this map to sort the result list by the path. 702a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) std::map<base::FilePath, DictionaryValue*> files; 715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 72868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) const int options = (base::FileEnumerator::FILES | 73868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) base::FileEnumerator::DIRECTORIES | 74868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) base::FileEnumerator::SHOW_SYM_LINKS); 75868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) base::FileEnumerator enumerator(root_path, true /* recursive */, options); 765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) int64 total_size = 0; 782a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) for (base::FilePath current = enumerator.Next(); !current.empty(); 795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) current = enumerator.Next()) { 80868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) base::FileEnumerator::FileInfo info = enumerator.GetInfo(); 81868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) int64 size = info.GetSize(); 82868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) const bool is_directory = info.IsDirectory(); 83868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) const bool is_symbolic_link = file_util::IsLink(info.GetName()); 84868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) const base::Time last_modified = info.GetLastModifiedTime(); 855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* entry = new base::DictionaryValue; 875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) entry->SetString("path", current.value()); 885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Use double instead of integer for large files. 895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) entry->SetDouble("size", size); 905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) entry->SetBoolean("is_directory", is_directory); 915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) entry->SetBoolean("is_symbolic_link", is_symbolic_link); 925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) entry->SetString( 935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) "last_modified", 945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) google_apis::util::FormatTimeAsStringLocaltime(last_modified)); 95c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) // Print lower 9 bits in octal format. 96c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) entry->SetString( 97c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) "permission", 98868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) base::StringPrintf("%03o", info.stat().st_mode & 0x1ff)); 995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) files[current] = entry; 1005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) total_size += size; 1025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 1035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Convert |files| into |gcache_contents|. 1052a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) for (std::map<base::FilePath, DictionaryValue*>::const_iterator 1065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) iter = files.begin(); iter != files.end(); ++iter) { 1075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) gcache_contents->Append(iter->second); 1085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 1095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) gcache_summary->SetDouble("total_size", total_size); 1115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Gets the available disk space for the path |home_path|. 1142a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void GetFreeDiskSpace(const base::FilePath& home_path, 1155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* local_storage_summary) { 1165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(!BrowserThread::CurrentlyOn(BrowserThread::UI)); 1175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(local_storage_summary); 1185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const int64 free_space = base::SysInfo::AmountOfFreeDiskSpace(home_path); 1205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) local_storage_summary->SetDouble("free_space", free_space); 1215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Formats |entry| into text. 1242a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)std::string FormatEntry(const base::FilePath& path, 125c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::ResourceEntry& entry) { 126b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 127b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 1285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) using base::StringAppendF; 1295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::string out; 1315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, "%s\n", path.AsUTF8Unsafe().c_str()); 1325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " title: %s\n", entry.title().c_str()); 1338bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) StringAppendF(&out, " local_id: %s\n", entry.local_id().c_str()); 1345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " resource_id: %s\n", entry.resource_id().c_str()); 1353551c9c881056c480085172ff9840cab31610854Torne (Richard Coles) StringAppendF(&out, " parent_local_id: %s\n", 1363551c9c881056c480085172ff9840cab31610854Torne (Richard Coles) entry.parent_local_id().c_str()); 137c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) StringAppendF(&out, " shared_with_me: %s\n", 138c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) entry.shared_with_me() ? "true" : "false"); 1395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const drive::PlatformFileInfoProto& file_info = entry.file_info(); 1415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " file_info\n"); 142a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) StringAppendF(&out, " size: %" PRId64 "\n", file_info.size()); 1435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " is_directory: %d\n", file_info.is_directory()); 1445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " is_symbolic_link: %d\n", 1455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_info.is_symbolic_link()); 1465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const base::Time last_modified = base::Time::FromInternalValue( 1485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_info.last_modified()); 1495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const base::Time last_accessed = base::Time::FromInternalValue( 1505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_info.last_accessed()); 1515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const base::Time creation_time = base::Time::FromInternalValue( 1525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_info.creation_time()); 1535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " last_modified: %s\n", 154b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) google_apis::util::FormatTimeAsString(last_modified).c_str()); 1555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " last_accessed: %s\n", 156b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) google_apis::util::FormatTimeAsString(last_accessed).c_str()); 1575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " creation_time: %s\n", 158b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) google_apis::util::FormatTimeAsString(creation_time).c_str()); 1595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 1605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (entry.has_file_specific_info()) { 16190dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) const drive::FileSpecificInfo& file_specific_info = 1625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) entry.file_specific_info(); 1635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " alternate_url: %s\n", 1645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_specific_info.alternate_url().c_str()); 1655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " content_mime_type: %s\n", 1665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_specific_info.content_mime_type().c_str()); 1675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " file_md5: %s\n", 168868fa2fe829687343ffae624259930155e16dbd8Torne (Richard Coles) file_specific_info.md5().c_str()); 1695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " document_extension: %s\n", 1705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_specific_info.document_extension().c_str()); 1715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) StringAppendF(&out, " is_hosted_document: %d\n", 1725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_specific_info.is_hosted_document()); 1735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 1745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 175c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) if (entry.has_directory_specific_info()) { 176c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) StringAppendF(&out, " directory_info\n"); 17790dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) const drive::DirectorySpecificInfo& directory_specific_info = 178c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) entry.directory_specific_info(); 179a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) StringAppendF(&out, " changestamp: %" PRId64 "\n", 180c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) directory_specific_info.changestamp()); 181c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) } 182c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) 1835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return out; 1845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 1855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 186a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles)std::string SeverityToString(logging::LogSeverity severity) { 187a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) switch (severity) { 188a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) case logging::LOG_INFO: 189a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) return "info"; 190a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) case logging::LOG_WARNING: 191a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) return "warning"; 192a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) case logging::LOG_ERROR: 193a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) return "error"; 194a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) default: // Treat all other higher severities as ERROR. 195a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) return "error"; 196a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) } 197a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles)} 198a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) 1995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)// Class to handle messages from chrome://drive-internals. 2005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)class DriveInternalsWebUIHandler : public content::WebUIMessageHandler { 2015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) public: 2025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DriveInternalsWebUIHandler() 2032a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) : last_sent_event_id_(-1), 2045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_(this) { 2055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) virtual ~DriveInternalsWebUIHandler() { 2085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 2095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) private: 2115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // WebUIMessageHandler override. 2125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) virtual void RegisterMessages() OVERRIDE; 2135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 21490dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) // Returns a DriveIntegrationService. 21590dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) drive::DriveIntegrationService* GetIntegrationService(); 2165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 21758537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) // Returns a DriveService instance. 21858537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::DriveServiceInterface* GetDriveService(); 21958537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) 22058537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) // Returns a FileSystem instance. 22158537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::FileSystemInterface* GetFileSystem(); 22258537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) 2235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Called when the page is first loaded. 2245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void OnPageLoaded(const base::ListValue* args); 2255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Updates respective sections. 2275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void UpdateDriveRelatedFlagsSection(); 2285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void UpdateDriveRelatedPreferencesSection(); 2295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void UpdateAuthStatusSection( 230eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveServiceInterface* drive_service); 2312a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void UpdateAboutResourceSection( 232eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveServiceInterface* drive_service); 2332a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void UpdateAppListSection( 234eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveServiceInterface* drive_service); 2355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void UpdateLocalMetadataSection( 236b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive::DebugInfoCollector* debug_info_collector); 237b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) void UpdateDeltaUpdateStatusSection( 238b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive::DebugInfoCollector* debug_info_collector); 239c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) void UpdateInFlightOperationsSection(drive::JobListInterface* job_list); 2405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void UpdateGCacheContentsSection(); 241c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) void UpdateFileSystemContentsSection(); 2425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void UpdateLocalStorageUsageSection(); 243b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) void UpdateCacheContentsSection( 244b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive::DebugInfoCollector* debug_info_collector); 245c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) void UpdateEventLogSection(); 2465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Called when GetGCacheContents() is complete. 2485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void OnGetGCacheContents(base::ListValue* gcache_contents, 2495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* cache_summary); 2505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 251a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles) // Called when GetResourceEntryByPath() is complete. 252a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles) void OnGetResourceEntryByPath(const base::FilePath& path, 253a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles) drive::FileError error, 254a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles) scoped_ptr<drive::ResourceEntry> entry); 2555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Called when ReadDirectoryByPath() is complete. 2572a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void OnReadDirectoryByPath(const base::FilePath& parent_path, 258c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) drive::FileError error, 259c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) scoped_ptr<drive::ResourceEntryVector> entries); 2605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 261c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) // Called as the iterator for DebugInfoCollector::IterateFileCache(). 2628bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) void UpdateCacheEntry(const std::string& local_id, 263c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::FileCacheEntry& cache_entry); 2645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Called when GetFreeDiskSpace() is complete. 2665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void OnGetFreeDiskSpace(base::DictionaryValue* local_storage_summary); 2675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2682a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // Called when GetAboutResource() call to DriveService is complete. 2692a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void OnGetAboutResource( 2702a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) google_apis::GDataErrorCode status, 2712a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) scoped_ptr<google_apis::AboutResource> about_resource); 2722a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 2732a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // Called when GetAppList() call to DriveService is complete. 2742a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void OnGetAppList( 2752a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) google_apis::GDataErrorCode status, 2762a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) scoped_ptr<google_apis::AppList> app_list); 2772a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 278c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) // Callback for DebugInfoCollector::GetMetadata for local update. 2792a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void OnGetFilesystemMetadataForLocal( 280c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::FileSystemMetadata& metadata); 2812a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 282c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) // Callback for DebugInfoCollector::GetMetadata for delta update. 2832a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void OnGetFilesystemMetadataForDeltaUpdate( 284c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::FileSystemMetadata& metadata); 2855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 2865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Called when the page requests periodic update. 2875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) void OnPeriodicUpdate(const base::ListValue* args); 2885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 289f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) // Called when the corresponding button on the page is pressed. 2902a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void ClearAccessToken(const base::ListValue* args); 2912a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) void ClearRefreshToken(const base::ListValue* args); 292f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) void ReloadDriveFileSystem(const base::ListValue* args); 293c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) void ListFileEntries(const base::ListValue* args); 294c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) 295f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) // Called after file system reload for ReloadDriveFileSystem is done. 296f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) void ReloadFinished(bool success); 297f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 2982a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // The last event sent to the JavaScript side. 2992a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) int last_sent_event_id_; 3002a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 3015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::WeakPtrFactory<DriveInternalsWebUIHandler> weak_ptr_factory_; 3025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DISALLOW_COPY_AND_ASSIGN(DriveInternalsWebUIHandler); 3035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)}; 3045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3052a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::OnGetAboutResource( 3062a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) google_apis::GDataErrorCode status, 3072a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) scoped_ptr<google_apis::AboutResource> parsed_about_resource) { 308b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 309b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 3105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (status != google_apis::HTTP_SUCCESS) { 3112a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) LOG(ERROR) << "Failed to get about resource"; 3125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return; 3135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 3142a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) DCHECK(parsed_about_resource); 3152a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 3162a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::DictionaryValue about_resource; 3172a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) about_resource.SetDouble("account-quota-total", 3182a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) parsed_about_resource->quota_bytes_total()); 3192a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) about_resource.SetDouble("account-quota-used", 3202a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) parsed_about_resource->quota_bytes_used()); 3212a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) about_resource.SetDouble("account-largest-changestamp-remote", 3222a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) parsed_about_resource->largest_change_id()); 3232a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) about_resource.SetString("root-resource-id", 3242a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) parsed_about_resource->root_folder_id()); 3252a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 3262a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) web_ui()->CallJavascriptFunction("updateAboutResource", about_resource); 3272a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)} 3285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3292a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::OnGetAppList( 3302a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) google_apis::GDataErrorCode status, 3312a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) scoped_ptr<google_apis::AppList> parsed_app_list) { 332b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 333b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 3342a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) if (status != google_apis::HTTP_SUCCESS) { 3352a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) LOG(ERROR) << "Failed to get app list"; 3362a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) return; 3372a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) } 3382a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) DCHECK(parsed_app_list); 3395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3402a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::DictionaryValue app_list; 3412a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) app_list.SetString("etag", parsed_app_list->etag()); 3425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3432a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::ListValue* items = new base::ListValue(); 3442a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) for (size_t i = 0; i < parsed_app_list->items().size(); ++i) { 3452a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) const google_apis::AppResource* app = parsed_app_list->items()[i]; 3462a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::DictionaryValue* app_data = new base::DictionaryValue(); 3472a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) app_data->SetString("name", app->name()); 3482a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) app_data->SetString("application_id", app->application_id()); 3492a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) app_data->SetString("object_type", app->object_type()); 3502a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) app_data->SetBoolean("supports_create", app->supports_create()); 3515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3522a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) items->Append(app_data); 3535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 3542a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) app_list.Set("items", items); 3555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3562a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) web_ui()->CallJavascriptFunction("updateAppList", app_list); 3575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 3585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 3595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::RegisterMessages() { 3605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->RegisterMessageCallback( 3615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) "pageLoaded", 3625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnPageLoaded, 3635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 3645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->RegisterMessageCallback( 3655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) "periodicUpdate", 3665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnPeriodicUpdate, 3675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 3682a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) web_ui()->RegisterMessageCallback( 3692a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) "clearAccessToken", 3702a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::ClearAccessToken, 3712a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 3722a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) web_ui()->RegisterMessageCallback( 3732a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) "clearRefreshToken", 3742a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::ClearRefreshToken, 3752a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 376c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) web_ui()->RegisterMessageCallback( 377f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) "reloadDriveFileSystem", 378f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::ReloadDriveFileSystem, 379f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 380f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) web_ui()->RegisterMessageCallback( 381c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) "listFileEntries", 382c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::ListFileEntries, 383c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 3845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 3855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 38690dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)drive::DriveIntegrationService* 38790dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles)DriveInternalsWebUIHandler::GetIntegrationService() { 388b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 389b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 3905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) Profile* profile = Profile::FromWebUI(web_ui()); 391d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles) drive::DriveIntegrationService* service = 392d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles) drive::DriveIntegrationServiceFactory::FindForProfile(profile); 393d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles) if (!service || !service->is_enabled()) 394d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles) return NULL; 395d0247b1b59f9c528cb6df88b4f2b9afaf80d181eTorne (Richard Coles) return service; 3965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 3975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 39858537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)drive::DriveServiceInterface* DriveInternalsWebUIHandler::GetDriveService() { 39958537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 40058537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) 40158537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) Profile* profile = Profile::FromWebUI(web_ui()); 40258537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) return drive::util::GetDriveServiceByProfile(profile); 40358537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)} 40458537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) 40558537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)drive::FileSystemInterface* DriveInternalsWebUIHandler::GetFileSystem() { 40658537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 40758537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) 40858537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) Profile* profile = Profile::FromWebUI(web_ui()); 40958537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) return drive::util::GetFileSystemByProfile(profile); 41058537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles)} 41158537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) 4125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::OnPageLoaded(const base::ListValue* args) { 4135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 4145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 41590dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) drive::DriveIntegrationService* integration_service = 41690dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) GetIntegrationService(); 41790dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) // |integration_service| may be NULL in the guest/incognito mode. 41890dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) if (!integration_service) 4195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return; 4205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 421eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveServiceInterface* drive_service = 42290dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) integration_service->drive_service(); 4235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(drive_service); 424b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive::DebugInfoCollector* debug_info_collector = 42590dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) integration_service->debug_info_collector(); 426b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(debug_info_collector); 4275821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UpdateDriveRelatedFlagsSection(); 4295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UpdateDriveRelatedPreferencesSection(); 4305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UpdateAuthStatusSection(drive_service); 4312a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) UpdateAboutResourceSection(drive_service); 4322a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) UpdateAppListSection(drive_service); 433b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) UpdateLocalMetadataSection(debug_info_collector); 434b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) UpdateDeltaUpdateStatusSection(debug_info_collector); 43590dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) UpdateInFlightOperationsSection(integration_service->job_list()); 4365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UpdateGCacheContentsSection(); 437b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) UpdateCacheContentsSection(debug_info_collector); 4385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) UpdateLocalStorageUsageSection(); 4392a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 4402a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // When the drive-internals page is reloaded by the reload key, the page 4412a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // content is recreated, but this WebUI object is not (instead, OnPageLoaded 4422a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // is called again). In that case, we have to forget the last sent ID here, 4432a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // and resent whole the logs to the page. 4442a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) last_sent_event_id_ = -1; 445c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) UpdateEventLogSection(); 4465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 4475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::UpdateDriveRelatedFlagsSection() { 449b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 450b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 4515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const char* kDriveRelatedFlags[] = { 452eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::switches::kEnableDriveV2Api, 453b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) chromeos::switches::kDisableDrive, 4545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) }; 4555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::ListValue flags; 4575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (size_t i = 0; i < arraysize(kDriveRelatedFlags); ++i) { 4585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const std::string key = kDriveRelatedFlags[i]; 4595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::string value = "(not set)"; 4605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (CommandLine::ForCurrentProcess()->HasSwitch(key)) 4615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) value = CommandLine::ForCurrentProcess()->GetSwitchValueASCII(key); 4625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* flag = new DictionaryValue; 4635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) flag->SetString("key", key); 4642a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) flag->SetString("value", value.empty() ? "(set)" : value); 4655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) flags.Append(flag); 4665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 4675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateDriveRelatedFlags", flags); 4695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 4705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::UpdateDriveRelatedPreferencesSection() { 472b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 473b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 4745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const char* kDriveRelatedPreferences[] = { 4755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) prefs::kDisableDrive, 4765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) prefs::kDisableDriveOverCellular, 4775821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) prefs::kDisableDriveHostedFiles, 4785821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) }; 4795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) Profile* profile = Profile::FromWebUI(web_ui()); 4815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) PrefService* pref_service = profile->GetPrefs(); 4825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::ListValue preferences; 4845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (size_t i = 0; i < arraysize(kDriveRelatedPreferences); ++i) { 4855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const std::string key = kDriveRelatedPreferences[i]; 4865821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // As of now, all preferences are boolean. 4875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const std::string value = 4885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) (pref_service->GetBoolean(key.c_str()) ? "true" : "false"); 4895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* preference = new DictionaryValue; 4905821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) preference->SetString("key", key); 4915821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) preference->SetString("value", value); 4925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) preferences.Append(preference); 4935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 4945821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateDriveRelatedPreferences", 4965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) preferences); 4975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 4985821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 4995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::UpdateAuthStatusSection( 500eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveServiceInterface* drive_service) { 501b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 5025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(drive_service); 5035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 5045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue auth_status; 5055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) auth_status.SetBoolean("has-refresh-token", 5065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) drive_service->HasRefreshToken()); 5075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) auth_status.SetBoolean("has-access-token", 5085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) drive_service->HasAccessToken()); 5095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateAuthStatus", auth_status); 5105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 5115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 5122a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::UpdateAboutResourceSection( 513eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveServiceInterface* drive_service) { 514b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 5155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(drive_service); 5165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 5172a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) drive_service->GetAboutResource( 5182a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnGetAboutResource, 5195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 5205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 5215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 5222a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::UpdateAppListSection( 523eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveServiceInterface* drive_service) { 524b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 5255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(drive_service); 5265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 5272a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) drive_service->GetAppList( 5282a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnGetAppList, 5292a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 5302a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)} 5312a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 5322a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::UpdateLocalMetadataSection( 533b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive::DebugInfoCollector* debug_info_collector) { 5342a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 535b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(debug_info_collector); 5362a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 537b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) debug_info_collector->GetMetadata( 5382a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnGetFilesystemMetadataForLocal, 5392a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 5402a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)} 5412a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 5422a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::OnGetFilesystemMetadataForLocal( 543c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::FileSystemMetadata& metadata) { 5442a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 5452a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 5465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue local_metadata; 5475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) local_metadata.SetDouble("account-largest-changestamp-local", 5485821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) metadata.largest_changestamp); 5495821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) local_metadata.SetBoolean("account-metadata-refreshing", metadata.refreshing); 5505821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateLocalMetadata", local_metadata); 5515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 5525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 5532a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::ClearAccessToken(const base::ListValue* args) { 554b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 555b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 55658537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::DriveServiceInterface* drive_service = GetDriveService(); 55758537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) if (drive_service) 55858537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive_service->ClearAccessToken(); 5592a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)} 5602a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 5612a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::ClearRefreshToken( 5622a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) const base::ListValue* args) { 563b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 564b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 56558537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::DriveServiceInterface* drive_service = GetDriveService(); 56658537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) if (drive_service) 56758537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive_service->ClearRefreshToken(); 5682a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)} 5692a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 570f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)void DriveInternalsWebUIHandler::ReloadDriveFileSystem( 571f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) const base::ListValue* args) { 572f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 573f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 574f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) drive::DriveIntegrationService* integration_service = 575f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) GetIntegrationService(); 576f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) if (integration_service) { 577f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) integration_service->ClearCacheAndRemountFileSystem( 578f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::ReloadFinished, 579f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 580f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) } 581f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)} 582f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 583f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)void DriveInternalsWebUIHandler::ReloadFinished(bool success) { 584f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 585f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 586f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) web_ui()->CallJavascriptFunction("updateReloadStatus", 587f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) base::FundamentalValue(success)); 588f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles)} 589f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) 590c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)void DriveInternalsWebUIHandler::ListFileEntries(const base::ListValue* args) { 591b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 592b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 593c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) UpdateFileSystemContentsSection(); 594c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)} 595c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) 596b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)void DriveInternalsWebUIHandler::UpdateDeltaUpdateStatusSection( 597b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive::DebugInfoCollector* debug_info_collector) { 5982a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 599b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(debug_info_collector); 6002a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 601b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) debug_info_collector->GetMetadata( 6022a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::Bind( 6032a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) &DriveInternalsWebUIHandler::OnGetFilesystemMetadataForDeltaUpdate, 6042a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr())); 6052a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)} 6062a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 6072a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)void DriveInternalsWebUIHandler::OnGetFilesystemMetadataForDeltaUpdate( 608c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::FileSystemMetadata& metadata) { 6092a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 610b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 611c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) Profile* profile = Profile::FromWebUI(web_ui()); 612eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch drive::DriveNotificationManager* drive_notification_manager = 61358537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::DriveNotificationManagerFactory::GetForBrowserContext(profile); 614c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) if (!drive_notification_manager) 615c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) return; 6165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 6175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue delta_update_status; 618c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) delta_update_status.SetBoolean( 619c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) "push-notification-enabled", 620b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive_notification_manager->push_notification_enabled()); 6215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) delta_update_status.SetString( 6225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) "last-update-check-time", 6235821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) google_apis::util::FormatTimeAsStringLocaltime( 6245821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) metadata.last_update_check_time)); 6255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) delta_update_status.SetString( 6265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) "last-update-check-error", 627c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) drive::FileErrorToString(metadata.last_update_check_error)); 6285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 6295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateDeltaUpdateStatus", 6305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) delta_update_status); 6315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 6325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 6335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::UpdateInFlightOperationsSection( 634c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) drive::JobListInterface* job_list) { 635b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 636b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(job_list); 637b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 638c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) std::vector<drive::JobInfo> info_list = job_list->GetJobInfoList(); 6395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 6405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::ListValue in_flight_operations; 641c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) for (size_t i = 0; i < info_list.size(); ++i) { 642c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::JobInfo& info = info_list[i]; 6435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 6445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* dict = new DictionaryValue; 645c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) dict->SetInteger("id", info.job_id); 646c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) dict->SetString("type", drive::JobTypeToString(info.job_type)); 647c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) dict->SetString("file_path", info.file_path.AsUTF8Unsafe()); 648c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) dict->SetString("state", drive::JobStateToString(info.state)); 649c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) dict->SetDouble("progress_current", info.num_completed_bytes); 650c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) dict->SetDouble("progress_total", info.num_total_bytes); 6515821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) in_flight_operations.Append(dict); 6525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 6535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateInFlightOperations", 6545821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) in_flight_operations); 6555821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 6565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 6575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::UpdateGCacheContentsSection() { 658b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 659b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 6605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Start updating the GCache contents section. 6615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) Profile* profile = Profile::FromWebUI(web_ui()); 662c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const base::FilePath root_path = drive::util::GetCacheRootPath(profile); 6635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::ListValue* gcache_contents = new ListValue; 6645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* gcache_summary = new DictionaryValue; 6655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) BrowserThread::PostBlockingPoolTaskAndReply( 6665821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) FROM_HERE, 6675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&GetGCacheContents, 6685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) root_path, 6695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) gcache_contents, 6705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) gcache_summary), 6715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnGetGCacheContents, 6725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr(), 6735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Owned(gcache_contents), 6745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Owned(gcache_summary))); 6755821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 6765821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 677c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)void DriveInternalsWebUIHandler::UpdateFileSystemContentsSection() { 678b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 679b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 68058537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::DriveServiceInterface* drive_service = GetDriveService(); 68158537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::FileSystemInterface* file_system = GetFileSystem(); 68258537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) if (!drive_service || !file_system) 683c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) return; 68458537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) 6855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Start updating the file system tree section, if we have access token. 68658537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) if (!drive_service->HasAccessToken()) 6875821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return; 6885821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 6895821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Start rendering the file system tree as text. 690c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const base::FilePath root_path = drive::util::GetDriveGrandRootPath(); 6912a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 692f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) file_system->GetResourceEntry( 6935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) root_path, 694a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnGetResourceEntryByPath, 6955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr(), 6965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) root_path)); 6975821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 698f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) file_system->ReadDirectory( 6995821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) root_path, 7005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnReadDirectoryByPath, 7015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr(), 7025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) root_path)); 7035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 7045821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 7055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::UpdateLocalStorageUsageSection() { 706b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 707b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 7085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Propagate the amount of local free space in bytes. 7092a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::FilePath home_path; 7105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (PathService::Get(base::DIR_HOME, &home_path)) { 7115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* local_storage_summary = new DictionaryValue; 7125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) BrowserThread::PostBlockingPoolTaskAndReply( 7135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) FROM_HERE, 7145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&GetFreeDiskSpace, home_path, local_storage_summary), 7155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnGetFreeDiskSpace, 7165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr(), 7175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Owned(local_storage_summary))); 7185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } else { 7195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) LOG(ERROR) << "Home directory not found"; 7205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 7215821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 7225821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 723b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles)void DriveInternalsWebUIHandler::UpdateCacheContentsSection( 724b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) drive::DebugInfoCollector* debug_info_collector) { 725b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 726b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(debug_info_collector); 727b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 728b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) debug_info_collector->IterateFileCache( 729c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::UpdateCacheEntry, 730c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) weak_ptr_factory_.GetWeakPtr()), 731c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) base::Bind(&base::DoNothing)); 7325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 7335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 734c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles)void DriveInternalsWebUIHandler::UpdateEventLogSection() { 735b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 736b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 737eb525c5499e34cc9c4b825d6d9e75bb07cc06aceBen Murdoch const std::vector<drive::EventLogger::Event> log = 738c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) drive::util::GetLogHistory(); 7392a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 7402a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::ListValue list; 7412a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) for (size_t i = 0; i < log.size(); ++i) { 7422a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) // Skip events which were already sent. 7432a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) if (log[i].id <= last_sent_event_id_) 7442a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) continue; 7452a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 746a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) std::string severity = SeverityToString(log[i].severity); 747a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) 7482a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::DictionaryValue* dict = new DictionaryValue; 7492a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) dict->SetString("key", 7502a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) google_apis::util::FormatTimeAsStringLocaltime(log[i].when)); 751a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) dict->SetString("value", "[" + severity + "] " + log[i].what); 752a36e5920737c6adbddd3e43b760e5de8431db6e0Torne (Richard Coles) dict->SetString("class", "log-" + severity); 7532a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) list.Append(dict); 7542a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) last_sent_event_id_ = log[i].id; 7552a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) } 7562a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) if (!list.empty()) 7572a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) web_ui()->CallJavascriptFunction("updateEventLog", list); 7582a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles)} 7592a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) 7605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::OnGetGCacheContents( 7615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::ListValue* gcache_contents, 7625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* gcache_summary) { 763b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 7645821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(gcache_contents); 7655821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(gcache_summary); 766b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 7675821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateGCacheContents", 7685821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) *gcache_contents, 7695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) *gcache_summary); 7705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 7715821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 772a93a17c8d99d686bd4a1511e5504e5e6cc9fcadfTorne (Richard Coles)void DriveInternalsWebUIHandler::OnGetResourceEntryByPath( 7732a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) const base::FilePath& path, 774c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) drive::FileError error, 775c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) scoped_ptr<drive::ResourceEntry> entry) { 776b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 777b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 778c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) if (error == drive::FILE_ERROR_OK) { 7795821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(entry.get()); 7805821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const base::StringValue value(FormatEntry(path, *entry) + "\n"); 7815821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateFileSystemContents", value); 7825821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 7835821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 7845821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 7855821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::OnReadDirectoryByPath( 7862a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) const base::FilePath& parent_path, 787c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) drive::FileError error, 788c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) scoped_ptr<drive::ResourceEntryVector> entries) { 789b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 790b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 791c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) if (error == drive::FILE_ERROR_OK) { 7925821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(entries.get()); 7935821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 79458537e28ecd584eab876aee8be7156509866d23aTorne (Richard Coles) drive::FileSystemInterface* file_system = GetFileSystem(); 7955821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) std::string file_system_as_text; 7965821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) for (size_t i = 0; i < entries->size(); ++i) { 797c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::ResourceEntry& entry = (*entries)[i]; 7982a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) const base::FilePath current_path = parent_path.Append( 7992a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) base::FilePath::FromUTF8Unsafe(entry.base_name())); 8005821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8015821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) file_system_as_text.append(FormatEntry(current_path, entry) + "\n"); 8025821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8035821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) if (entry.file_info().is_directory()) { 804f2477e01787aa58f445919b809d89e252beef54fTorne (Richard Coles) file_system->ReadDirectory( 8055821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) current_path, 8065821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::Bind(&DriveInternalsWebUIHandler::OnReadDirectoryByPath, 8075821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) weak_ptr_factory_.GetWeakPtr(), 8085821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) current_path)); 8095821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 8105821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 8115821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8125821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // There may be pending ReadDirectoryByPath() calls, but we can update 8135821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // the page with what we have now. This results in progressive 8145821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // updates, which is good for a large file system. 8155821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) const base::StringValue value(file_system_as_text); 8165821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateFileSystemContents", value); 8175821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) } 8185821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 8195821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8205821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::UpdateCacheEntry( 8218bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) const std::string& local_id, 822c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) const drive::FileCacheEntry& cache_entry) { 823b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 824b2df76ea8fec9e32f6f3718986dba0d95315b29cTorne (Richard Coles) 8255821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) // Convert |cache_entry| into a dictionary. 8265821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue value; 8278bcbed890bc3ce4d7a057a8f32cab53fa534672eTorne (Richard Coles) value.SetString("local_id", local_id); 8285821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) value.SetString("md5", cache_entry.md5()); 8295821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) value.SetBoolean("is_present", cache_entry.is_present()); 8305821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) value.SetBoolean("is_pinned", cache_entry.is_pinned()); 8315821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) value.SetBoolean("is_dirty", cache_entry.is_dirty()); 8325821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8335821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction("updateCacheContents", value); 8345821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 8355821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8365821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::OnGetFreeDiskSpace( 8375821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) base::DictionaryValue* local_storage_summary) { 8385821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 8395821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(local_storage_summary); 8405821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8415821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui()->CallJavascriptFunction( 8425821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) "updateLocalStorageUsage", *local_storage_summary); 8435821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 8445821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8455821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)void DriveInternalsWebUIHandler::OnPeriodicUpdate(const base::ListValue* args) { 8465821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 8475821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 84890dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) drive::DriveIntegrationService* integration_service = 84990dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) GetIntegrationService(); 85090dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) // |integration_service| may be NULL in the guest/incognito mode. 85190dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) if (!integration_service) 8525821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) return; 8535821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 85490dce4d38c5ff5333bea97d859d4e484e27edf0cTorne (Richard Coles) UpdateInFlightOperationsSection(integration_service->job_list()); 855c2e0dbddbe15c98d52c4786dac06cb8952a8ae6dTorne (Richard Coles) UpdateEventLogSection(); 8565821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 8575821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8585821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace 8595821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8605821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)DriveInternalsUI::DriveInternalsUI(content::WebUI* web_ui) 8615821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) : WebUIController(web_ui) { 8625821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) web_ui->AddMessageHandler(new DriveInternalsWebUIHandler()); 8635821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8642a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) content::WebUIDataSource* source = 8652a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) content::WebUIDataSource::Create(chrome::kChromeUIDriveInternalsHost); 8662a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) source->AddResourcePath("drive_internals.css", IDR_DRIVE_INTERNALS_CSS); 8672a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) source->AddResourcePath("drive_internals.js", IDR_DRIVE_INTERNALS_JS); 8682a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) source->SetDefaultResource(IDR_DRIVE_INTERNALS_HTML); 8695821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8705821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) Profile* profile = Profile::FromWebUI(web_ui); 8712a99a7e74a7f215066514fe81d2bfa6639d9edddTorne (Richard Coles) content::WebUIDataSource::Add(profile, source); 8725821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} 8735821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles) 8745821806d5e7f356e8fa4b058a389a808ea183019Torne (Richard Coles)} // namespace chromeos 875