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

Unified Diff: chrome/browser/devtools/devtools_ui_bindings.cc

Issue 2864263002: [DevTools] Expose TCP targets config in frontend, use it for Node (Closed)
Patch Set: panel Created 3 years, 7 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/devtools/devtools_ui_bindings.cc
diff --git a/chrome/browser/devtools/devtools_ui_bindings.cc b/chrome/browser/devtools/devtools_ui_bindings.cc
index 91c8e15961c4498f37f758265a6baeb3cbb2d310..cbdff152343b165bf5f17ae7439f163692fa77b8 100644
--- a/chrome/browser/devtools/devtools_ui_bindings.cc
+++ b/chrome/browser/devtools/devtools_ui_bindings.cc
@@ -100,6 +100,12 @@ static const char kRemotePageActionReload[] = "reload";
static const char kRemotePageActionActivate[] = "activate";
static const char kRemotePageActionClose[] = "close";
+static const char kConfigDiscoverUsbDevices[] = "discoverUsbDevices";
+static const char kConfigPortForwardingEnabled[] = "portForwardingEnabled";
+static const char kConfigPortForwardingConfig[] = "portForwardingConfig";
+static const char kConfigNetworkDiscoveryEnabled[] = "networkDiscoveryEnabled";
+static const char kConfigNetworkDiscoveryConfig[] = "networkDiscoveryConfig";
+
// This constant should be in sync with
// the constant at shell_devtools_frontend.cc.
const size_t kMaxMessageChunkSize = IPC::Channel::kMaximumMessageSize / 4;
@@ -918,30 +924,63 @@ void DevToolsUIBindings::ResetZoom() {
void DevToolsUIBindings::SetDevicesDiscoveryConfig(
bool discover_usb_devices,
bool port_forwarding_enabled,
- const std::string& port_forwarding_config) {
- base::DictionaryValue* config_dict = nullptr;
- std::unique_ptr<base::Value> parsed_config =
+ const std::string& port_forwarding_config,
+ bool network_discovery_enabled,
+ const std::string& network_discovery_config) {
+ base::DictionaryValue* port_forwarding_dict = nullptr;
+ std::unique_ptr<base::Value> parsed_port_forwarding =
base::JSONReader::Read(port_forwarding_config);
- if (!parsed_config || !parsed_config->GetAsDictionary(&config_dict))
+ if (!parsed_port_forwarding ||
+ !parsed_port_forwarding->GetAsDictionary(&port_forwarding_dict)) {
+ return;
+ }
+
+ base::ListValue* network_list = nullptr;
+ std::unique_ptr<base::Value> parsed_network =
+ base::JSONReader::Read(network_discovery_config);
+ if (!parsed_network || !parsed_network->GetAsList(&network_list))
return;
profile_->GetPrefs()->SetBoolean(
prefs::kDevToolsDiscoverUsbDevicesEnabled, discover_usb_devices);
profile_->GetPrefs()->SetBoolean(
prefs::kDevToolsPortForwardingEnabled, port_forwarding_enabled);
- profile_->GetPrefs()->Set(
- prefs::kDevToolsPortForwardingConfig, *config_dict);
+ profile_->GetPrefs()->Set(prefs::kDevToolsPortForwardingConfig,
+ *port_forwarding_dict);
+ profile_->GetPrefs()->SetBoolean(prefs::kDevToolsDiscoverTCPTargetsEnabled,
+ network_discovery_enabled);
+ profile_->GetPrefs()->Set(prefs::kDevToolsTCPDiscoveryConfig, *network_list);
}
void DevToolsUIBindings::DevicesDiscoveryConfigUpdated() {
- CallClientFunction(
- "DevToolsAPI.devicesDiscoveryConfigChanged",
- profile_->GetPrefs()->FindPreference(
- prefs::kDevToolsDiscoverUsbDevicesEnabled)->GetValue(),
- profile_->GetPrefs()->FindPreference(
- prefs::kDevToolsPortForwardingEnabled)->GetValue(),
- profile_->GetPrefs()->FindPreference(
- prefs::kDevToolsPortForwardingConfig)->GetValue());
+ base::DictionaryValue config;
+ config.Set(kConfigDiscoverUsbDevices,
+ profile_->GetPrefs()
+ ->FindPreference(prefs::kDevToolsDiscoverUsbDevicesEnabled)
+ ->GetValue()
+ ->CreateDeepCopy());
+ config.Set(kConfigPortForwardingEnabled,
+ profile_->GetPrefs()
+ ->FindPreference(prefs::kDevToolsPortForwardingEnabled)
+ ->GetValue()
+ ->CreateDeepCopy());
+ config.Set(kConfigPortForwardingConfig,
+ profile_->GetPrefs()
+ ->FindPreference(prefs::kDevToolsPortForwardingConfig)
+ ->GetValue()
+ ->CreateDeepCopy());
+ config.Set(kConfigNetworkDiscoveryEnabled,
+ profile_->GetPrefs()
+ ->FindPreference(prefs::kDevToolsDiscoverTCPTargetsEnabled)
+ ->GetValue()
+ ->CreateDeepCopy());
+ config.Set(kConfigNetworkDiscoveryConfig,
+ profile_->GetPrefs()
+ ->FindPreference(prefs::kDevToolsTCPDiscoveryConfig)
+ ->GetValue()
+ ->CreateDeepCopy());
+ CallClientFunction("DevToolsAPI.devicesDiscoveryConfigChanged", &config,
+ nullptr, nullptr);
}
void DevToolsUIBindings::SendPortForwardingStatus(const base::Value& status) {
@@ -968,6 +1007,14 @@ void DevToolsUIBindings::SetDevicesUpdatesEnabled(bool enabled) {
pref_change_registrar_.Add(prefs::kDevToolsPortForwardingConfig,
base::Bind(&DevToolsUIBindings::DevicesDiscoveryConfigUpdated,
base::Unretained(this)));
+ pref_change_registrar_.Add(
+ prefs::kDevToolsDiscoverTCPTargetsEnabled,
+ base::Bind(&DevToolsUIBindings::DevicesDiscoveryConfigUpdated,
+ base::Unretained(this)));
+ pref_change_registrar_.Add(
+ prefs::kDevToolsTCPDiscoveryConfig,
+ base::Bind(&DevToolsUIBindings::DevicesDiscoveryConfigUpdated,
+ base::Unretained(this)));
port_status_serializer_.reset(new PortForwardingStatusSerializer(
base::Bind(&DevToolsUIBindings::SendPortForwardingStatus,
base::Unretained(this)),
« no previous file with comments | « chrome/browser/devtools/devtools_ui_bindings.h ('k') | third_party/WebKit/Source/devtools/front_end/devices/DevicesView.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698