Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/net/net_log_logger.h" | 5 #include "chrome/browser/net/net_log_logger.h" |
| 6 | 6 |
| 7 #include <stdio.h> | 7 #include <stdio.h> |
| 8 | 8 |
| 9 #include "base/bind.h" | |
| 9 #include "base/file_util.h" | 10 #include "base/file_util.h" |
| 10 #include "base/json/json_writer.h" | 11 #include "base/json/json_writer.h" |
| 11 #include "base/logging.h" | 12 #include "base/logging.h" |
| 12 #include "base/memory/scoped_ptr.h" | 13 #include "base/message_loop.h" |
| 14 #include "base/string_number_conversions.h" | |
| 15 #include "base/string_util.h" | |
| 16 #include "base/threading/platform_thread.h" | |
| 13 #include "base/threading/thread_restrictions.h" | 17 #include "base/threading/thread_restrictions.h" |
| 18 #include "base/utf_string_conversions.h" | |
| 14 #include "base/values.h" | 19 #include "base/values.h" |
| 20 #include "chrome/browser/browser_process.h" | |
| 21 #include "chrome/browser/net/chrome_net_log.h" | |
| 15 #include "chrome/browser/ui/webui/net_internals/net_internals_ui.h" | 22 #include "chrome/browser/ui/webui/net_internals/net_internals_ui.h" |
| 23 #include "content/public/browser/browser_thread.h" | |
| 16 | 24 |
| 17 NetLogLogger::NetLogLogger(const FilePath &log_path) { | 25 #if defined(OS_ANDROID) |
| 18 if (!log_path.empty()) { | 26 #include "chrome/browser/android/intent_helper.h" |
| 27 #endif | |
| 28 | |
| 29 using content::BrowserThread; | |
| 30 | |
| 31 NetLogLogger::NetLogLogger(const FilePath &log_path) : log_path_(log_path) { | |
| 32 OpenFile(); | |
| 33 } | |
| 34 | |
| 35 void NetLogLogger::OpenFile() { | |
| 36 if (!log_path_.empty()) { | |
| 19 base::ThreadRestrictions::ScopedAllowIO allow_io; | 37 base::ThreadRestrictions::ScopedAllowIO allow_io; |
| 20 FILE* fp = file_util::OpenFile(log_path, "w"); | 38 FILE* fp = file_util::OpenFile(log_path_, "w"); |
| 21 if (!fp) { | 39 if (!fp) { |
| 22 LOG(ERROR) << "Could not open file " << log_path.value() | 40 LOG(ERROR) << "Could not open file " << log_path_.value() |
| 23 << " for net logging"; | 41 << " for net logging"; |
| 24 return; | 42 return; |
| 25 } | 43 } |
| 26 file_.Set(fp); | 44 file_.Set(fp); |
| 27 | 45 |
| 28 // Write constants to the output file. This allows loading files that have | 46 // Write constants to the output file. This allows loading files that have |
| 29 // different source and event types, as they may be added and removed | 47 // different source and event types, as they may be added and removed |
| 30 // between Chrome versions. | 48 // between Chrome versions. |
| 31 scoped_ptr<Value> value(NetInternalsUI::GetConstants()); | 49 scoped_ptr<Value> value(NetInternalsUI::GetConstants()); |
| 32 std::string json; | 50 std::string json; |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 50 // instead of integer identifiers allows logs from older versions to be | 68 // instead of integer identifiers allows logs from older versions to be |
| 51 // loaded, though a little extra parsing has to be done when loading a log. | 69 // loaded, though a little extra parsing has to be done when loading a log. |
| 52 std::string json; | 70 std::string json; |
| 53 base::JSONWriter::Write(value.get(), &json); | 71 base::JSONWriter::Write(value.get(), &json); |
| 54 if (!file_.get()) { | 72 if (!file_.get()) { |
| 55 VLOG(1) << json; | 73 VLOG(1) << json; |
| 56 } else { | 74 } else { |
| 57 fprintf(file_.get(), "%s,\n", json.c_str()); | 75 fprintf(file_.get(), "%s,\n", json.c_str()); |
| 58 } | 76 } |
| 59 } | 77 } |
| 78 | |
| 79 static NetLogLogger* g_net_log_logger_ = NULL; | |
|
droger
2012/12/10 10:37:07
Can you put |g_net_log_logger_| in an anonymous na
| |
| 80 | |
| 81 // static | |
| 82 void NetLogLogger::StartNetLog() { | |
| 83 if (!BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING)) { | |
| 84 BrowserThread::PostTask( | |
| 85 BrowserThread::FILE_USER_BLOCKING, | |
| 86 FROM_HERE, | |
| 87 base::Bind(&StartNetLog)); | |
| 88 return; | |
| 89 } | |
| 90 | |
| 91 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING)); | |
| 92 if (g_net_log_logger_ || !g_browser_process->net_log()) | |
| 93 return; | |
| 94 | |
| 95 FilePath log_path; | |
| 96 if (!file_util::CreateTemporaryFile(&log_path)) | |
| 97 return; | |
| 98 | |
| 99 g_net_log_logger_ = new NetLogLogger(log_path); | |
| 100 g_browser_process->net_log()->AddThreadSafeObserver( | |
| 101 g_net_log_logger_, net::NetLog::LOG_ALL_BUT_BYTES); | |
| 102 } | |
| 103 | |
| 104 // static | |
| 105 void NetLogLogger::StopNetLog() { | |
| 106 if (!BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING)) { | |
| 107 BrowserThread::PostTask( | |
| 108 BrowserThread::FILE_USER_BLOCKING, | |
| 109 FROM_HERE, | |
| 110 base::Bind(&StopNetLog)); | |
| 111 return; | |
| 112 } | |
| 113 | |
| 114 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING)); | |
| 115 if (!g_net_log_logger_) | |
| 116 return; | |
| 117 | |
| 118 if (g_browser_process->net_log()) | |
| 119 g_browser_process->net_log()->RemoveThreadSafeObserver(g_net_log_logger_); | |
| 120 | |
| 121 if (g_net_log_logger_->file_.get()) | |
| 122 g_net_log_logger_->file_.Close(); | |
| 123 | |
| 124 if (!g_net_log_logger_->log_path_.empty()) | |
| 125 file_util::Delete(g_net_log_logger_->log_path_, false); | |
| 126 | |
| 127 for (unsigned i = 0; i < g_net_log_logger_->files_to_delete_.size(); i++) { | |
| 128 FilePath file_to_attach_path(g_net_log_logger_->files_to_delete_[i]); | |
| 129 file_util::Delete(file_to_attach_path, false); | |
| 130 } | |
| 131 | |
| 132 delete g_net_log_logger_; | |
| 133 g_net_log_logger_ = NULL; | |
| 134 } | |
| 135 | |
| 136 // static | |
| 137 void NetLogLogger::SendNetLog() { | |
| 138 if (!BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING)) { | |
| 139 BrowserThread::PostTask( | |
| 140 BrowserThread::FILE_USER_BLOCKING, | |
| 141 FROM_HERE, | |
| 142 base::Bind(&SendNetLog)); | |
| 143 return; | |
| 144 } | |
| 145 | |
| 146 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING)); | |
| 147 if (!g_net_log_logger_) | |
| 148 return; | |
| 149 | |
| 150 if (g_net_log_logger_->file_.get()) | |
| 151 g_net_log_logger_->file_.Close(); | |
| 152 | |
| 153 FilePath temp_file_path; | |
| 154 if (file_util::CreateTemporaryFile(&temp_file_path)) { | |
| 155 FilePath::StringType file_to_attach(temp_file_path.value()); | |
| 156 FilePath file_to_attach_path(file_to_attach); | |
| 157 | |
| 158 if (file_util::ReplaceFile(g_net_log_logger_->log_path_, | |
| 159 file_to_attach_path)) { | |
| 160 #if defined(OS_POSIX) | |
| 161 // Users, group and others can read, write and traverse. | |
| 162 int mode = file_util::FILE_PERMISSION_MASK; | |
| 163 file_util::SetPosixFilePermissions(file_to_attach_path, mode); | |
| 164 #endif // defined(OS_POSIX) | |
| 165 g_net_log_logger_->files_to_delete_.push_back( | |
| 166 file_to_attach_path.value()); | |
| 167 | |
| 168 BrowserThread::PostTask( | |
| 169 BrowserThread::UI, | |
| 170 FROM_HERE, | |
| 171 base::Bind(&SendEmail, g_net_log_logger_->files_to_delete_.back())); | |
| 172 } | |
| 173 } | |
| 174 | |
| 175 g_net_log_logger_->OpenFile(); | |
| 176 } | |
| 177 | |
| 178 // static | |
| 179 void NetLogLogger::SendEmail(const FilePath::StringType& file_to_attach) { | |
| 180 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 181 | |
| 182 #if defined(OS_ANDROID) | |
| 183 std::string email; | |
| 184 std::string subject = "net_internals_log"; | |
| 185 std::string title = "test_title"; | |
| 186 std::string body = "Net Internals log data"; | |
| 187 chrome::android::SendEmail( | |
| 188 UTF8ToUTF16(email), UTF8ToUTF16(subject), | |
| 189 UTF8ToUTF16(body), UTF8ToUTF16(title), UTF8ToUTF16(file_to_attach)); | |
| 190 #endif | |
| 191 } | |
| OLD | NEW |