OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/devtools/device/devtools_android_bridge.h" | 5 #include "chrome/browser/devtools/device/devtools_android_bridge.h" |
6 | 6 |
7 #include <stddef.h> | 7 #include <stddef.h> |
8 #include <algorithm> | 8 #include <algorithm> |
9 #include <map> | 9 #include <map> |
10 #include <set> | 10 #include <set> |
(...skipping 15 matching lines...) Expand all Loading... |
26 #include "base/strings/string_util.h" | 26 #include "base/strings/string_util.h" |
27 #include "base/strings/stringprintf.h" | 27 #include "base/strings/stringprintf.h" |
28 #include "base/strings/utf_string_conversions.h" | 28 #include "base/strings/utf_string_conversions.h" |
29 #include "base/threading/thread.h" | 29 #include "base/threading/thread.h" |
30 #include "base/values.h" | 30 #include "base/values.h" |
31 #include "chrome/browser/devtools/device/adb/adb_device_provider.h" | 31 #include "chrome/browser/devtools/device/adb/adb_device_provider.h" |
32 #include "chrome/browser/devtools/device/cast_device_provider.h" | 32 #include "chrome/browser/devtools/device/cast_device_provider.h" |
33 #include "chrome/browser/devtools/device/port_forwarding_controller.h" | 33 #include "chrome/browser/devtools/device/port_forwarding_controller.h" |
34 #include "chrome/browser/devtools/device/tcp_device_provider.h" | 34 #include "chrome/browser/devtools/device/tcp_device_provider.h" |
35 #include "chrome/browser/devtools/device/usb/usb_device_provider.h" | 35 #include "chrome/browser/devtools/device/usb/usb_device_provider.h" |
36 #include "chrome/browser/devtools/device/webrtc/webrtc_device_provider.h" | |
37 #include "chrome/browser/devtools/devtools_protocol.h" | 36 #include "chrome/browser/devtools/devtools_protocol.h" |
38 #include "chrome/browser/devtools/devtools_target_impl.h" | 37 #include "chrome/browser/devtools/devtools_target_impl.h" |
39 #include "chrome/browser/devtools/devtools_window.h" | 38 #include "chrome/browser/devtools/devtools_window.h" |
40 #include "chrome/browser/devtools/remote_debugging_server.h" | 39 #include "chrome/browser/devtools/remote_debugging_server.h" |
41 #include "chrome/browser/profiles/profile.h" | 40 #include "chrome/browser/profiles/profile.h" |
42 #include "chrome/browser/signin/profile_oauth2_token_service_factory.h" | |
43 #include "chrome/browser/signin/signin_manager_factory.h" | |
44 #include "chrome/common/chrome_switches.h" | 41 #include "chrome/common/chrome_switches.h" |
45 #include "chrome/common/pref_names.h" | 42 #include "chrome/common/pref_names.h" |
46 #include "components/keyed_service/content/browser_context_dependency_manager.h" | 43 #include "components/keyed_service/content/browser_context_dependency_manager.h" |
47 #include "components/signin/core/browser/profile_oauth2_token_service.h" | 44 #include "components/signin/core/browser/profile_oauth2_token_service.h" |
48 #include "components/signin/core/browser/signin_manager.h" | 45 #include "components/signin/core/browser/signin_manager.h" |
49 #include "content/public/browser/devtools_agent_host.h" | 46 #include "content/public/browser/devtools_agent_host.h" |
50 #include "content/public/browser/devtools_external_agent_proxy.h" | 47 #include "content/public/browser/devtools_external_agent_proxy.h" |
51 #include "content/public/browser/devtools_external_agent_proxy_delegate.h" | 48 #include "content/public/browser/devtools_external_agent_proxy_delegate.h" |
52 #include "content/public/browser/user_metrics.h" | 49 #include "content/public/browser/user_metrics.h" |
53 #include "net/base/escape.h" | 50 #include "net/base/escape.h" |
54 #include "net/base/host_port_pair.h" | 51 #include "net/base/host_port_pair.h" |
55 #include "net/base/net_errors.h" | 52 #include "net/base/net_errors.h" |
56 | 53 |
57 using content::BrowserThread; | 54 using content::BrowserThread; |
58 | 55 |
59 namespace { | 56 namespace { |
60 | 57 |
61 const char kPageListRequest[] = "/json"; | 58 const char kPageListRequest[] = "/json"; |
62 const char kVersionRequest[] = "/json/version"; | 59 const char kVersionRequest[] = "/json/version"; |
63 const char kClosePageRequest[] = "/json/close/%s"; | 60 const char kClosePageRequest[] = "/json/close/%s"; |
64 const char kNewPageRequestWithURL[] = "/json/new?%s"; | 61 const char kNewPageRequestWithURL[] = "/json/new?%s"; |
65 const char kActivatePageRequest[] = "/json/activate/%s"; | 62 const char kActivatePageRequest[] = "/json/activate/%s"; |
66 const char kBrowserTargetSocket[] = "/devtools/browser"; | 63 const char kBrowserTargetSocket[] = "/devtools/browser"; |
67 const int kAdbPollingIntervalMs = 1000; | 64 const int kAdbPollingIntervalMs = 1000; |
68 | 65 |
69 const char kPageReloadCommand[] = "Page.reload"; | 66 const char kPageReloadCommand[] = "Page.reload"; |
70 | 67 |
71 const char kWebViewSocketPrefix[] = "webview_devtools_remote"; | 68 const char kWebViewSocketPrefix[] = "webview_devtools_remote"; |
72 | 69 |
73 bool IsWebRTCDeviceProviderEnabled() { | |
74 return base::CommandLine::ForCurrentProcess()->HasSwitch( | |
75 switches::kEnableDevToolsExperiments); | |
76 } | |
77 | |
78 bool BrowserIdFromString(const std::string& browser_id_str, | 70 bool BrowserIdFromString(const std::string& browser_id_str, |
79 DevToolsAndroidBridge::BrowserId* browser_id) { | 71 DevToolsAndroidBridge::BrowserId* browser_id) { |
80 size_t colon_pos = browser_id_str.find(':'); | 72 size_t colon_pos = browser_id_str.find(':'); |
81 if (colon_pos == std::string::npos) | 73 if (colon_pos == std::string::npos) |
82 return false; | 74 return false; |
83 browser_id->first = browser_id_str.substr(0, colon_pos); | 75 browser_id->first = browser_id_str.substr(0, colon_pos); |
84 browser_id->second = browser_id_str.substr(colon_pos + 1); | 76 browser_id->second = browser_id_str.substr(colon_pos + 1); |
85 return true; | 77 return true; |
86 } | 78 } |
87 | 79 |
(...skipping 181 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
269 DevToolsAndroidBridge* DevToolsAndroidBridge::Factory::GetForProfile( | 261 DevToolsAndroidBridge* DevToolsAndroidBridge::Factory::GetForProfile( |
270 Profile* profile) { | 262 Profile* profile) { |
271 return static_cast<DevToolsAndroidBridge*>(GetInstance()-> | 263 return static_cast<DevToolsAndroidBridge*>(GetInstance()-> |
272 GetServiceForBrowserContext(profile->GetOriginalProfile(), true)); | 264 GetServiceForBrowserContext(profile->GetOriginalProfile(), true)); |
273 } | 265 } |
274 | 266 |
275 DevToolsAndroidBridge::Factory::Factory() | 267 DevToolsAndroidBridge::Factory::Factory() |
276 : BrowserContextKeyedServiceFactory( | 268 : BrowserContextKeyedServiceFactory( |
277 "DevToolsAndroidBridge", | 269 "DevToolsAndroidBridge", |
278 BrowserContextDependencyManager::GetInstance()) { | 270 BrowserContextDependencyManager::GetInstance()) { |
279 if (IsWebRTCDeviceProviderEnabled()) { | |
280 DependsOn(ProfileOAuth2TokenServiceFactory::GetInstance()); | |
281 DependsOn(SigninManagerFactory::GetInstance()); | |
282 } | |
283 } | 271 } |
284 | 272 |
285 DevToolsAndroidBridge::Factory::~Factory() {} | 273 DevToolsAndroidBridge::Factory::~Factory() {} |
286 | 274 |
287 KeyedService* DevToolsAndroidBridge::Factory::BuildServiceInstanceFor( | 275 KeyedService* DevToolsAndroidBridge::Factory::BuildServiceInstanceFor( |
288 content::BrowserContext* context) const { | 276 content::BrowserContext* context) const { |
289 Profile* profile = Profile::FromBrowserContext(context); | 277 Profile* profile = Profile::FromBrowserContext(context); |
290 | 278 |
291 ProfileOAuth2TokenService* token_service = nullptr; | 279 return new DevToolsAndroidBridge(profile); |
292 SigninManagerBase* signin_manager = nullptr; | |
293 | |
294 if (IsWebRTCDeviceProviderEnabled()) { | |
295 token_service = ProfileOAuth2TokenServiceFactory::GetForProfile(profile); | |
296 signin_manager = SigninManagerFactory::GetForProfile(profile); | |
297 } | |
298 | |
299 return new DevToolsAndroidBridge( | |
300 profile, signin_manager, token_service); | |
301 } | 280 } |
302 | 281 |
303 // AgentHostDelegate ---------------------------------------------------------- | 282 // AgentHostDelegate ---------------------------------------------------------- |
304 | 283 |
305 class DevToolsAndroidBridge::AgentHostDelegate | 284 class DevToolsAndroidBridge::AgentHostDelegate |
306 : public content::DevToolsExternalAgentProxyDelegate, | 285 : public content::DevToolsExternalAgentProxyDelegate, |
307 public AndroidDeviceManager::AndroidWebSocket::Delegate { | 286 public AndroidDeviceManager::AndroidWebSocket::Delegate { |
308 public: | 287 public: |
309 static scoped_refptr<content::DevToolsAgentHost> GetOrCreateAgentHost( | 288 static scoped_refptr<content::DevToolsAgentHost> GetOrCreateAgentHost( |
310 DevToolsAndroidBridge* bridge, | 289 DevToolsAndroidBridge* bridge, |
(...skipping 414 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
725 browsers_.push_back(new RemoteBrowser(serial, *it)); | 704 browsers_.push_back(new RemoteBrowser(serial, *it)); |
726 } | 705 } |
727 } | 706 } |
728 | 707 |
729 DevToolsAndroidBridge::RemoteDevice::~RemoteDevice() { | 708 DevToolsAndroidBridge::RemoteDevice::~RemoteDevice() { |
730 } | 709 } |
731 | 710 |
732 // DevToolsAndroidBridge ------------------------------------------------------ | 711 // DevToolsAndroidBridge ------------------------------------------------------ |
733 | 712 |
734 DevToolsAndroidBridge::DevToolsAndroidBridge( | 713 DevToolsAndroidBridge::DevToolsAndroidBridge( |
735 Profile* profile, | 714 Profile* profile) |
736 SigninManagerBase* signin_manager, | |
737 ProfileOAuth2TokenService* const token_service) | |
738 : profile_(profile), | 715 : profile_(profile), |
739 signin_manager_(signin_manager), | |
740 token_service_(token_service), | |
741 device_manager_(AndroidDeviceManager::Create()), | 716 device_manager_(AndroidDeviceManager::Create()), |
742 task_scheduler_(base::Bind(&DevToolsAndroidBridge::ScheduleTaskDefault)), | 717 task_scheduler_(base::Bind(&DevToolsAndroidBridge::ScheduleTaskDefault)), |
743 port_forwarding_controller_(new PortForwardingController(profile, this)), | 718 port_forwarding_controller_(new PortForwardingController(profile, this)), |
744 weak_factory_(this) { | 719 weak_factory_(this) { |
745 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 720 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
746 pref_change_registrar_.Init(profile_->GetPrefs()); | 721 pref_change_registrar_.Init(profile_->GetPrefs()); |
747 pref_change_registrar_.Add(prefs::kDevToolsDiscoverUsbDevicesEnabled, | 722 pref_change_registrar_.Add(prefs::kDevToolsDiscoverUsbDevicesEnabled, |
748 base::Bind(&DevToolsAndroidBridge::CreateDeviceProviders, | 723 base::Bind(&DevToolsAndroidBridge::CreateDeviceProviders, |
749 base::Unretained(this))); | 724 base::Unretained(this))); |
750 CreateDeviceProviders(); | 725 CreateDeviceProviders(); |
(...skipping 204 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
955 PrefService* service = profile_->GetPrefs(); | 930 PrefService* service = profile_->GetPrefs(); |
956 const PrefService::Preference* pref = | 931 const PrefService::Preference* pref = |
957 service->FindPreference(prefs::kDevToolsDiscoverUsbDevicesEnabled); | 932 service->FindPreference(prefs::kDevToolsDiscoverUsbDevicesEnabled); |
958 const base::Value* pref_value = pref->GetValue(); | 933 const base::Value* pref_value = pref->GetValue(); |
959 | 934 |
960 bool enabled; | 935 bool enabled; |
961 if (pref_value->GetAsBoolean(&enabled) && enabled) { | 936 if (pref_value->GetAsBoolean(&enabled) && enabled) { |
962 device_providers.push_back(new UsbDeviceProvider(profile_)); | 937 device_providers.push_back(new UsbDeviceProvider(profile_)); |
963 } | 938 } |
964 | 939 |
965 if (IsWebRTCDeviceProviderEnabled()) { | |
966 device_providers.push_back( | |
967 new WebRTCDeviceProvider(profile_, signin_manager_, token_service_)); | |
968 } | |
969 | |
970 device_manager_->SetDeviceProviders(device_providers); | 940 device_manager_->SetDeviceProviders(device_providers); |
971 if (NeedsDeviceListPolling()) { | 941 if (NeedsDeviceListPolling()) { |
972 StopDeviceListPolling(); | 942 StopDeviceListPolling(); |
973 StartDeviceListPolling(); | 943 StartDeviceListPolling(); |
974 } | 944 } |
975 } | 945 } |
OLD | NEW |