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