Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(176)

Side by Side Diff: chrome/browser/net/net_log_temp_file.cc

Issue 11635023: First cut at UI for saving net_logs data into a temporary file on (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/net/net_log_temp_file.h"
6
7 #include <stdio.h>
8
9 #include "base/bind.h"
10 #include "base/file_util.h"
11 #include "base/json/json_writer.h"
12 #include "base/logging.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"
17 #include "base/utf_string_conversions.h"
18 #include "base/values.h"
19 #include "chrome/browser/browser_process.h"
20 #include "chrome/browser/net/chrome_net_log.h"
21 #include "chrome/browser/net/net_log_logger.h"
22 #include "chrome/browser/ui/webui/net_internals/net_internals_ui.h"
23 #include "content/public/browser/browser_thread.h"
24
25 #if defined(OS_ANDROID)
26 #include "chrome/browser/android/intent_helper.h"
27 #endif
28
29 using content::BrowserThread;
30
31 NetLogTempFile::NetLogTempFile() : state_(UNINITIALIZED) {
32 BrowserThread::PostTask(
33 BrowserThread::FILE_USER_BLOCKING,
34 FROM_HERE,
35 base::Bind(&NetLogTempFile::Init, base::Unretained(this)));
36 }
37
38 NetLogTempFile::~NetLogTempFile() {
39 }
40
41 void NetLogTempFile::ProcessCommand(Command command) {
42 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING));
43 switch (command) {
44 case DO_START:
45 StartNetLog();
46 break;
47 case DO_STOP:
48 StopNetLog();
49 break;
50 case DO_SEND:
51 SendNetLog();
52 break;
53 default:
54 break;
55 }
56 }
57
58 Value* NetLogTempFile::NetLogTempFileToValue() {
59 base::DictionaryValue* dict = new base::DictionaryValue;
60
61 #ifndef NDEBUG
62 dict->SetString("file", log_path_.MaybeAsASCII());
63 #endif // NDEBUG
64
65 base::AutoLock lock(lock_);
66 switch (state_) {
67 case ALLOW_STOP:
68 dict->SetString("state", "ALLOW_STOP");
69 break;
70 case ALLOW_START_SEND:
71 dict->SetString("state", "ALLOW_START_SEND");
72 break;
73 default:
74 dict->SetString("state", "ALLOW_START");
75 break;
76 }
77 return dict;
78 }
79
80 bool GetTempNetLogDir(FilePath* path) {
81 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING));
82
83 FilePath temp_dir;
84 if (!file_util::GetTempDir(&temp_dir))
85 return false;
86
87 FilePath net_log_dir = temp_dir.Append(FILE_PATH_LITERAL("NetLog"));
88 if (file_util::PathExists(net_log_dir)) {
89 *path = net_log_dir;
90 return true;
91 }
92
93 if (!file_util::CreateDirectory(net_log_dir))
94 return false;
95
96 *path = net_log_dir;
97 return true;
98 }
99
100 void NetLogTempFile::Init() {
101 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING));
102
103 FilePath net_log_dir;
104
105 base::AutoLock lock(lock_);
106 if (!GetTempNetLogDir(&net_log_dir)) {
107 state_ = ALLOW_START;
108 return;
109 }
110 if (file_util::IsDirectoryEmpty(net_log_dir))
111 state_ = ALLOW_START;
112 else
113 state_ = ALLOW_START_SEND;
114 }
115
116 void NetLogTempFile::StartNetLog() {
117 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING));
118
119 if (!g_browser_process->net_log())
120 return;
121
122 base::AutoLock lock(lock_);
123 if (state_ == ALLOW_STOP)
124 return;
125
126 FilePath net_log_dir;
127 if (!GetTempNetLogDir(&net_log_dir))
128 return;
129
130 file_util::FileEnumerator file_iter(
131 net_log_dir, false, file_util::FileEnumerator::FILES);
132 for (FilePath current = file_iter.Next(); !current.empty();
133 current = file_iter.Next()) {
134 file_util::Delete(current, false);
135 }
136
137 if (!file_util::CreateTemporaryFileInDir(net_log_dir, &log_path_))
138 return;
139
140 net_log_logger_.reset(new NetLogLogger(log_path_));
141 net_log_logger_->StartObserving(g_browser_process->net_log());
142 state_ = ALLOW_STOP;
143 }
144
145 void NetLogTempFile::StopNetLog() {
146 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING));
147
148 if (!g_browser_process->net_log())
149 return;
150
151 base::AutoLock lock(lock_);
152 if (state_ != ALLOW_STOP)
153 return;
154
155 net_log_logger_->StopObserving();
156 net_log_logger_.reset();
157 state_ = ALLOW_START_SEND;
158 }
159
160 void NetLogTempFile::SendNetLog() {
161 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE_USER_BLOCKING));
162
163 base::AutoLock lock(lock_);
164 if (state_ != ALLOW_START_SEND)
165 return;
166
167 FilePath net_log_dir;
168 if (!GetTempNetLogDir(&net_log_dir))
169 return;
170
171 FilePath file_to_send;
172 file_util::FileEnumerator file_iter(
173 net_log_dir, false, file_util::FileEnumerator::FILES);
174 for (FilePath current = file_iter.Next(); !current.empty();
175 current = file_iter.Next()) {
176 file_to_send = current;
177 break;
178 }
179 if (file_to_send.empty())
180 return;
181
182 #if defined(OS_POSIX)
183 // Users, group and others can read, write and traverse.
184 int mode = file_util::FILE_PERMISSION_MASK;
185 file_util::SetPosixFilePermissions(file_to_send, mode);
186 #endif // defined(OS_POSIX)
187
188 BrowserThread::PostTask(
189 BrowserThread::UI,
190 FROM_HERE,
191 base::Bind(&NetLogTempFile::SendEmail, file_to_send));
192 }
193
194 // static
195 void NetLogTempFile::SendEmail(const FilePath& file_to_send) {
196 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
197
198 #if defined(OS_ANDROID)
199 std::string email;
200 std::string subject = "net_internals_log";
201 std::string title = "test_title";
202 std::string body = "Net Internals log data";
203 FilePath::StringType file_to_attach(file_to_send.value());
204 chrome::android::SendEmail(
205 UTF8ToUTF16(email), UTF8ToUTF16(subject),
206 UTF8ToUTF16(body), UTF8ToUTF16(title), UTF8ToUTF16(file_to_attach));
207 #endif
208 }
OLDNEW
« no previous file with comments | « chrome/browser/net/net_log_temp_file.h ('k') | chrome/browser/resources/net_export/net_export.html » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698