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/android/dev_tools_server.h" | 5 #include "chrome/browser/android/dev_tools_server.h" |
6 | 6 |
7 #include <pwd.h> | 7 #include <pwd.h> |
8 #include <cstring> | 8 #include <cstring> |
9 | 9 |
10 #include "base/android/jni_string.h" | 10 #include "base/android/jni_string.h" |
(...skipping 163 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
174 | 174 |
175 const net::UnixDomainServerSocket::AuthCallback auth_callback_; | 175 const net::UnixDomainServerSocket::AuthCallback auth_callback_; |
176 | 176 |
177 DISALLOW_COPY_AND_ASSIGN(UnixDomainServerSocketFactory); | 177 DISALLOW_COPY_AND_ASSIGN(UnixDomainServerSocketFactory); |
178 }; | 178 }; |
179 | 179 |
180 } // namespace | 180 } // namespace |
181 | 181 |
182 DevToolsServer::DevToolsServer(const std::string& socket_name_prefix) | 182 DevToolsServer::DevToolsServer(const std::string& socket_name_prefix) |
183 : socket_name_(base::StringPrintf(kDevToolsChannelNameFormat, | 183 : socket_name_(base::StringPrintf(kDevToolsChannelNameFormat, |
184 socket_name_prefix.c_str())), | 184 socket_name_prefix.c_str())) { |
185 protocol_handler_(NULL) { | |
186 // Override the socket name if one is specified on the command line. | 185 // Override the socket name if one is specified on the command line. |
187 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); | 186 const CommandLine& command_line = *CommandLine::ForCurrentProcess(); |
188 if (command_line.HasSwitch(switches::kRemoteDebuggingSocketName)) { | 187 if (command_line.HasSwitch(switches::kRemoteDebuggingSocketName)) { |
189 socket_name_ = command_line.GetSwitchValueASCII( | 188 socket_name_ = command_line.GetSwitchValueASCII( |
190 switches::kRemoteDebuggingSocketName); | 189 switches::kRemoteDebuggingSocketName); |
191 } | 190 } |
192 } | 191 } |
193 | 192 |
194 DevToolsServer::~DevToolsServer() { | 193 DevToolsServer::~DevToolsServer() { |
195 Stop(); | 194 Stop(); |
196 } | 195 } |
197 | 196 |
198 void DevToolsServer::Start(bool allow_debug_permission) { | 197 void DevToolsServer::Start(bool allow_debug_permission) { |
199 if (protocol_handler_) | 198 if (protocol_handler_) |
200 return; | 199 return; |
201 | 200 |
202 net::UnixDomainServerSocket::AuthCallback auth_callback = | 201 net::UnixDomainServerSocket::AuthCallback auth_callback = |
203 allow_debug_permission ? | 202 allow_debug_permission ? |
204 base::Bind(&AuthorizeSocketAccessWithDebugPermission) : | 203 base::Bind(&AuthorizeSocketAccessWithDebugPermission) : |
205 base::Bind(&content::CanUserConnectToDevTools); | 204 base::Bind(&content::CanUserConnectToDevTools); |
206 scoped_ptr<content::DevToolsHttpHandler::ServerSocketFactory> factory( | 205 scoped_ptr<content::DevToolsHttpHandler::ServerSocketFactory> factory( |
207 new UnixDomainServerSocketFactory(socket_name_, auth_callback)); | 206 new UnixDomainServerSocketFactory(socket_name_, auth_callback)); |
208 protocol_handler_ = content::DevToolsHttpHandler::Start( | 207 protocol_handler_.reset(content::DevToolsHttpHandler::Start( |
209 factory.Pass(), | 208 factory.Pass(), |
210 base::StringPrintf(kFrontEndURL, content::GetWebKitRevision().c_str()), | 209 base::StringPrintf(kFrontEndURL, content::GetWebKitRevision().c_str()), |
211 new DevToolsServerDelegate(auth_callback), | 210 new DevToolsServerDelegate(auth_callback), |
212 base::FilePath()); | 211 base::FilePath())); |
213 } | 212 } |
214 | 213 |
215 void DevToolsServer::Stop() { | 214 void DevToolsServer::Stop() { |
216 if (!protocol_handler_) | 215 protocol_handler_.reset(); |
217 return; | |
218 // Note that the call to Stop() below takes care of |protocol_handler_| | |
219 // deletion. | |
220 protocol_handler_->Stop(); | |
221 protocol_handler_ = NULL; | |
222 } | 216 } |
223 | 217 |
224 bool DevToolsServer::IsStarted() const { | 218 bool DevToolsServer::IsStarted() const { |
225 return protocol_handler_; | 219 return protocol_handler_; |
226 } | 220 } |
227 | 221 |
228 bool RegisterDevToolsServer(JNIEnv* env) { | 222 bool RegisterDevToolsServer(JNIEnv* env) { |
229 return RegisterNativesImpl(env); | 223 return RegisterNativesImpl(env); |
230 } | 224 } |
231 | 225 |
(...skipping 20 matching lines...) Expand all Loading... |
252 jlong server, | 246 jlong server, |
253 jboolean enabled, | 247 jboolean enabled, |
254 jboolean allow_debug_permission) { | 248 jboolean allow_debug_permission) { |
255 DevToolsServer* devtools_server = reinterpret_cast<DevToolsServer*>(server); | 249 DevToolsServer* devtools_server = reinterpret_cast<DevToolsServer*>(server); |
256 if (enabled) { | 250 if (enabled) { |
257 devtools_server->Start(allow_debug_permission); | 251 devtools_server->Start(allow_debug_permission); |
258 } else { | 252 } else { |
259 devtools_server->Stop(); | 253 devtools_server->Stop(); |
260 } | 254 } |
261 } | 255 } |
OLD | NEW |