diff options
author | mnissler@chromium.org <mnissler@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-19 19:01:14 +0000 |
---|---|---|
committer | mnissler@chromium.org <mnissler@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-19 19:01:14 +0000 |
commit | 24f49bd3da572b7c94a5b66b60e49a0685a9912c (patch) | |
tree | 4e26e6721b527688c5ef60bcf647ea0469eacadc | |
parent | 489c42f10efb599a2a2f1c7adfb8fef8778bf47f (diff) | |
download | chromium_src-24f49bd3da572b7c94a5b66b60e49a0685a9912c.zip chromium_src-24f49bd3da572b7c94a5b66b60e49a0685a9912c.tar.gz chromium_src-24f49bd3da572b7c94a5b66b60e49a0685a9912c.tar.bz2 |
Convert CrOS proxy config serialization to protobuf format.
BUG=chromium-os:14214
TEST=manual, and suite_Smoke
Review URL: http://codereview.chromium.org/6873051
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@82136 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | chrome/browser/chromeos/login/signed_settings.cc | 20 | ||||
-rw-r--r-- | chrome/browser/chromeos/proxy_config_service_impl.cc | 268 | ||||
-rw-r--r-- | chrome/browser/chromeos/proxy_config_service_impl.h | 21 | ||||
-rw-r--r-- | chrome/browser/chromeos/proxy_cros_settings_provider.cc | 8 | ||||
-rw-r--r-- | net/proxy/proxy_bypass_rules.cc | 13 | ||||
-rw-r--r-- | net/proxy/proxy_bypass_rules.h | 6 |
6 files changed, 134 insertions, 202 deletions
diff --git a/chrome/browser/chromeos/login/signed_settings.cc b/chrome/browser/chromeos/login/signed_settings.cc index 93d22b4..b6ba4df 100644 --- a/chrome/browser/chromeos/login/signed_settings.cc +++ b/chrome/browser/chromeos/login/signed_settings.cc @@ -17,8 +17,8 @@ #include "chrome/browser/chromeos/login/authenticator.h" #include "chrome/browser/chromeos/login/ownership_service.h" #include "chrome/browser/chromeos/login/signed_settings_temp_storage.h" -#include "chrome/browser/policy/proto/device_management_backend.pb.h" #include "chrome/browser/policy/proto/chrome_device_policy.pb.h" +#include "chrome/browser/policy/proto/device_management_backend.pb.h" #include "content/browser/browser_thread.h" namespace chromeos { @@ -627,10 +627,9 @@ void StorePropertyOp::SetInPolicy(const std::string& prop, } else if (prop == kSettingProxyEverywhere) { // TODO(cmasone): NOTIMPLEMENTED() once http://crosbug.com/13052 is fixed. - // TODO(cmasone): Until then, we will have to parse serialized JSON - // representing proxy settings, as generated by - // ProxyConfigServiceImpl::Serialize(). The code needs to translate into a - // DeviceProxySettingsProto (defined in chrome_device_policy.proto). + em::DeviceProxySettingsProto* proxy = pol.mutable_device_proxy_settings(); + DCHECK(proxy->ParseFromString(value)); + } else { NOTREACHED(); } @@ -740,11 +739,12 @@ std::string RetrievePropertyOp::LookUpInPolicy(const std::string& prop) { } else if (prop == kSettingProxyEverywhere) { // TODO(cmasone): NOTIMPLEMENTED() once http://crosbug.com/13052 is fixed. - // TODO(cmasone): Until then, we will have to return serialized JSON - // representing proxy settings, to be consumed by - // ProxyConfigServiceImpl::Deserialize(). We need code to translate a - // DeviceProxySettingsProto (defined in chrome_device_policy.proto) into - // a serialzed JSON string of this form. + std::string serialized; + if (!pol.has_device_proxy_settings() || + !pol.device_proxy_settings().SerializeToString(&serialized)) + return ""; // Default to invalid proxy config (will be ignored). + return serialized; + } return std::string(); } diff --git a/chrome/browser/chromeos/proxy_config_service_impl.cc b/chrome/browser/chromeos/proxy_config_service_impl.cc index 3309d9e..26811be 100644 --- a/chrome/browser/chromeos/proxy_config_service_impl.cc +++ b/chrome/browser/chromeos/proxy_config_service_impl.cc @@ -11,8 +11,11 @@ #include "base/task.h" #include "chrome/browser/chromeos/cros/cros_library.h" #include "chrome/browser/chromeos/cros_settings_names.h" +#include "chrome/browser/policy/proto/chrome_device_policy.pb.h" +#include "chrome/browser/prefs/proxy_prefs.h" #include "content/browser/browser_thread.h" -#include "content/common/json_value_serializer.h" + +namespace em = enterprise_management; namespace chromeos { @@ -93,21 +96,6 @@ std::string ProxyConfigToString( return stream.str(); } -// Names used for dictionary values to serialize chromeos::ProxyConfig. -const char* kMode = "mode"; -const char* kSource = "src"; -const char* kAutomaticProxy = "auto"; -const char* kSingleProxy = "single"; -const char* kHttpProxy = "http"; -const char* kHttpsProxy = "https"; -const char* kFtpProxy = "ftp"; -const char* kSocksProxy = "socks"; -const char* kPACUrl = "pac"; -const char* kServer = "server"; -const char* kBypassRules = "bypass_rules"; -const char* kRulesNum = "num"; -const char* kRulesList = "list"; - } // namespace //---------- ProxyConfigServiceImpl::ProxyConfig::Setting methods -------------- @@ -119,64 +107,6 @@ bool ProxyConfigServiceImpl::ProxyConfig::Setting::CanBeWrittenByUser( return user_is_owner && source != ProxyConfig::SOURCE_POLICY; } -DictionaryValue* ProxyConfigServiceImpl::ProxyConfig::Setting::Encode() const { - DictionaryValue* dict = new DictionaryValue; - dict->SetInteger(kSource, source); - return dict; -} - -bool ProxyConfigServiceImpl::ProxyConfig::Setting::Decode( - DictionaryValue* dict) { - int int_source; - if (!dict->GetInteger(kSource, &int_source)) - return false; - source = static_cast<Source>(int_source); - return true; -} - -//------- ProxyConfigServiceImpl::ProxyConfig::AutomaticProxy methods ---------- - -DictionaryValue* - ProxyConfigServiceImpl::ProxyConfig::AutomaticProxy::Encode() const { - DictionaryValue* dict = Setting::Encode(); - if (!pac_url.is_empty()) - dict->SetString(kPACUrl, pac_url.spec()); - return dict; -} - -bool ProxyConfigServiceImpl::ProxyConfig::AutomaticProxy::Decode( - DictionaryValue* dict, Mode mode) { - if (!Setting::Decode(dict)) - return false; - if (mode == MODE_PAC_SCRIPT) { - std::string value; - if (!dict->GetString(kPACUrl, &value)) - return false; - pac_url = GURL(value); - } - return true; -} - -//--------- ProxyConfigServiceImpl::ProxyConfig::ManualProxy methods ----------- - -DictionaryValue* - ProxyConfigServiceImpl::ProxyConfig::ManualProxy::Encode() const { - DictionaryValue* dict = Setting::Encode(); - dict->SetString(kServer, server.ToURI()); - return dict; -} - -bool ProxyConfigServiceImpl::ProxyConfig::ManualProxy::Decode( - DictionaryValue* dict, net::ProxyServer::Scheme scheme) { - if (!Setting::Decode(dict)) - return false; - std::string value; - if (!dict->GetString(kServer, &value)) - return false; - server = net::ProxyServer::FromURI(value, scheme); - return true; -} - //----------- ProxyConfigServiceImpl::ProxyConfig: public methods -------------- void ProxyConfigServiceImpl::ProxyConfig::ToNetProxyConfig( @@ -258,106 +188,102 @@ ProxyConfigServiceImpl::ProxyConfig::ManualProxy* } bool ProxyConfigServiceImpl::ProxyConfig::Serialize(std::string* output) { - scoped_ptr<DictionaryValue> dict(new DictionaryValue); - dict->SetInteger(kMode, mode); - DictionaryValue* proxy_dict; + em::DeviceProxySettingsProto proxy_proto; switch (mode) { - case MODE_DIRECT: - case MODE_AUTO_DETECT: - case MODE_PAC_SCRIPT: - proxy_dict = automatic_proxy.Encode(); - dict->Set(kAutomaticProxy, proxy_dict); + case MODE_DIRECT: { + proxy_proto.set_proxy_mode(ProxyPrefs::kDirectProxyModeName); break; - case MODE_SINGLE_PROXY: - EncodeManualProxy(single_proxy, dict.get(), kSingleProxy); + } + case MODE_AUTO_DETECT: { + proxy_proto.set_proxy_mode(ProxyPrefs::kAutoDetectProxyModeName); break; - case MODE_PROXY_PER_SCHEME: - EncodeManualProxy(http_proxy, dict.get(), kHttpProxy); - EncodeManualProxy(https_proxy, dict.get(), kHttpsProxy); - EncodeManualProxy(ftp_proxy, dict.get(), kFtpProxy); - EncodeManualProxy(socks_proxy, dict.get(), kSocksProxy); + } + case MODE_PAC_SCRIPT: { + proxy_proto.set_proxy_mode(ProxyPrefs::kPacScriptProxyModeName); + if (!automatic_proxy.pac_url.is_empty()) + proxy_proto.set_proxy_pac_url(automatic_proxy.pac_url.spec()); break; - default: + } + case MODE_SINGLE_PROXY: { + proxy_proto.set_proxy_mode(ProxyPrefs::kFixedServersProxyModeName); + if (single_proxy.server.is_valid()) + proxy_proto.set_proxy_server(single_proxy.server.ToURI()); + break; + } + case MODE_PROXY_PER_SCHEME: { + proxy_proto.set_proxy_mode(ProxyPrefs::kFixedServersProxyModeName); + std::string spec; + EncodeAndAppendProxyServer("http", http_proxy.server, &spec); + EncodeAndAppendProxyServer("https", https_proxy.server, &spec); + EncodeAndAppendProxyServer("ftp", ftp_proxy.server, &spec); + EncodeAndAppendProxyServer("socks", socks_proxy.server, &spec); + if (!spec.empty()) + proxy_proto.set_proxy_server(spec); + break; + } + default: { NOTREACHED() << "Unrecognized proxy config mode"; break; - } - net::ProxyBypassRules::RuleList rules = bypass_rules.rules(); - if (!rules.empty()) { - DictionaryValue* bypass_dict = new DictionaryValue; - bypass_dict->SetInteger(kRulesNum, rules.size()); - ListValue* list = new ListValue; - for (size_t i = 0; i < rules.size(); ++i) { - list->Append(Value::CreateStringValue(rules[i]->ToString())); } - bypass_dict->Set(kRulesList, list); - dict->Set(kBypassRules, bypass_dict); } - JSONStringValueSerializer serializer(output); - return serializer.Serialize(*dict.get()); + proxy_proto.set_proxy_bypass_list(bypass_rules.ToString()); + return proxy_proto.SerializeToString(output); } bool ProxyConfigServiceImpl::ProxyConfig::Deserialize( const std::string& input) { - JSONStringValueSerializer serializer(input); - scoped_ptr<Value> value(serializer.Deserialize(NULL, NULL)); - if (!value.get() || value->GetType() != Value::TYPE_DICTIONARY) + em::DeviceProxySettingsProto proxy_proto; + if (!proxy_proto.ParseFromString(input)) return false; - DictionaryValue* dict = static_cast<DictionaryValue*>(value.get()); - int int_mode; - if (!dict->GetInteger(kMode, &int_mode)) - return false; - mode = static_cast<Mode>(int_mode); - DictionaryValue* proxy_dict = NULL; - switch (mode) { - case MODE_DIRECT: - case MODE_AUTO_DETECT: - case MODE_PAC_SCRIPT: - if (!dict->GetDictionary(kAutomaticProxy, &proxy_dict) || - !automatic_proxy.Decode(proxy_dict, mode)) - return false; - break; - case MODE_SINGLE_PROXY: - if (!DecodeManualProxy(dict, kSingleProxy, false, - net::ProxyServer::SCHEME_HTTP, &single_proxy)) - return false; - break; - case MODE_PROXY_PER_SCHEME: - if (!DecodeManualProxy(dict, kHttpProxy, true, - net::ProxyServer::SCHEME_HTTP, &http_proxy)) - return false; - if (!DecodeManualProxy(dict, kHttpsProxy, true, - net::ProxyServer::SCHEME_HTTP, &https_proxy)) - return false; - if (!DecodeManualProxy(dict, kFtpProxy, true, - net::ProxyServer::SCHEME_HTTP, &ftp_proxy)) - return false; - if (!DecodeManualProxy(dict, kSocksProxy, true, - net::ProxyServer::SCHEME_SOCKS5, &socks_proxy)) - return false; - // Make sure we have valid server for at least one of the protocols. - if (!(http_proxy.server.is_valid() || https_proxy.server.is_valid() || - ftp_proxy.server.is_valid() || socks_proxy.server.is_valid())) - return false; - break; - default: - NOTREACHED() << "Unrecognized proxy config mode"; - break; - } - DictionaryValue* bypass_dict = NULL; - if (dict->GetDictionary(kBypassRules, &bypass_dict)) { - int num_rules = 0; - if (bypass_dict->GetInteger(kRulesNum, &num_rules) && num_rules > 0) { - ListValue* list; - if (!bypass_dict->GetList(kRulesList, &list)) + + const std::string& mode_string(proxy_proto.proxy_mode()); + if (mode_string == ProxyPrefs::kDirectProxyModeName) { + mode = MODE_DIRECT; + } else if (mode_string == ProxyPrefs::kAutoDetectProxyModeName) { + mode = MODE_AUTO_DETECT; + } else if (mode_string == ProxyPrefs::kPacScriptProxyModeName) { + mode = MODE_PAC_SCRIPT; + if (proxy_proto.has_proxy_pac_url()) + automatic_proxy.pac_url = GURL(proxy_proto.proxy_pac_url()); + } else if (mode_string == ProxyPrefs::kFixedServersProxyModeName) { + net::ProxyConfig::ProxyRules rules; + rules.ParseFromString(proxy_proto.proxy_server()); + switch (rules.type) { + case net::ProxyConfig::ProxyRules::TYPE_NO_RULES: return false; - for (size_t i = 0; i < list->GetSize(); ++i) { - std::string rule; - if (!list->GetString(i, &rule)) + case net::ProxyConfig::ProxyRules::TYPE_SINGLE_PROXY: + if (!rules.single_proxy.is_valid()) return false; - bypass_rules.AddRuleFromString(rule); - } + mode = MODE_SINGLE_PROXY; + single_proxy.server = rules.single_proxy; + break; + case net::ProxyConfig::ProxyRules::TYPE_PROXY_PER_SCHEME: + // Make sure we have valid server for at least one of the protocols. + if (!rules.proxy_for_http.is_valid() && + !rules.proxy_for_https.is_valid() && + !rules.proxy_for_ftp.is_valid() && + !rules.fallback_proxy.is_valid()) { + return false; + } + mode = MODE_PROXY_PER_SCHEME; + if (rules.proxy_for_http.is_valid()) + http_proxy.server = rules.proxy_for_http; + if (rules.proxy_for_https.is_valid()) + https_proxy.server = rules.proxy_for_https; + if (rules.proxy_for_ftp.is_valid()) + ftp_proxy.server = rules.proxy_for_ftp; + if (rules.fallback_proxy.is_valid()) + socks_proxy.server = rules.fallback_proxy; + break; } + } else { + NOTREACHED() << "Unrecognized proxy config mode"; + return false; } + + if (proxy_proto.has_proxy_bypass_list()) + bypass_rules.ParseFromString(proxy_proto.proxy_bypass_list()); + return true; } @@ -367,22 +293,22 @@ std::string ProxyConfigServiceImpl::ProxyConfig::ToString() const { //----------- ProxyConfigServiceImpl::ProxyConfig: private methods ------------- -void ProxyConfigServiceImpl::ProxyConfig::EncodeManualProxy( - const ManualProxy& manual_proxy, DictionaryValue* dict, - const char* key_name) { - if (!manual_proxy.server.is_valid()) +// static +void ProxyConfigServiceImpl::ProxyConfig::EncodeAndAppendProxyServer( + const std::string& scheme, + const net::ProxyServer& server, + std::string* spec) { + if (!server.is_valid()) return; - DictionaryValue* proxy_dict = manual_proxy.Encode(); - dict->Set(key_name, proxy_dict); -} -bool ProxyConfigServiceImpl::ProxyConfig::DecodeManualProxy( - DictionaryValue* dict, const char* key_name, bool ok_if_absent, - net::ProxyServer::Scheme scheme, ManualProxy* manual_proxy) { - DictionaryValue* proxy_dict; - if (!dict->GetDictionary(key_name, &proxy_dict)) - return ok_if_absent; - return manual_proxy->Decode(proxy_dict, scheme); + if (!spec->empty()) + *spec += ';'; + + if (!scheme.empty()) { + *spec += scheme; + *spec += "="; + } + *spec += server.ToURI(); } //------------------- ProxyConfigServiceImpl: public methods ------------------- diff --git a/chrome/browser/chromeos/proxy_config_service_impl.h b/chrome/browser/chromeos/proxy_config_service_impl.h index bd1cbb6..7256a64 100644 --- a/chrome/browser/chromeos/proxy_config_service_impl.h +++ b/chrome/browser/chromeos/proxy_config_service_impl.h @@ -89,25 +89,17 @@ class ProxyConfigServiceImpl struct Setting { Setting() : source(SOURCE_NONE) {} bool CanBeWrittenByUser(bool user_is_owner); - virtual DictionaryValue* Encode() const; - bool Decode(DictionaryValue* dict); Source source; }; // Proxy setting for mode = direct or auto-detect or using pac script. struct AutomaticProxy : public Setting { - virtual DictionaryValue* Encode() const; - bool Decode(DictionaryValue* dict, Mode mode); - GURL pac_url; // Set if proxy is using pac script. }; // Proxy setting for mode = single-proxy or proxy-per-scheme. struct ManualProxy : public Setting { - virtual DictionaryValue* Encode() const; - bool Decode(DictionaryValue* dict, net::ProxyServer::Scheme scheme); - net::ProxyServer server; }; @@ -154,15 +146,10 @@ class ProxyConfigServiceImpl net::ProxyBypassRules bypass_rules; private: - // Encodes |manual_proxy| and adds it as value into |key_name| of |dict|. - void EncodeManualProxy(const ManualProxy& manual_proxy, - DictionaryValue* dict, const char* key_name); - // Decodes value of |key_name| in |dict| into |manual_proxy| with |scheme|; - // if |ok_if_absent| is true, function returns true if |key_name| doesn't - // exist in |dict|. - bool DecodeManualProxy(DictionaryValue* dict, const char* key_name, - bool ok_if_absent, net::ProxyServer::Scheme scheme, - ManualProxy* manual_proxy); + // Encodes the proxy server as "<url-scheme>=<proxy-scheme>://<proxy>" + static void EncodeAndAppendProxyServer(const std::string& scheme, + const net::ProxyServer& server, + std::string* spec); }; // Usual constructor. diff --git a/chrome/browser/chromeos/proxy_cros_settings_provider.cc b/chrome/browser/chromeos/proxy_cros_settings_provider.cc index 65cc4d9..c0d9047 100644 --- a/chrome/browser/chromeos/proxy_cros_settings_provider.cc +++ b/chrome/browser/chromeos/proxy_cros_settings_provider.cc @@ -282,7 +282,9 @@ net::ProxyServer ProxyCrosSettingsProvider::CreateProxyServerFromHost( const std::string& host, const ProxyConfigServiceImpl::ProxyConfig::ManualProxy& proxy, net::ProxyServer::Scheme scheme) const { - uint16 port = proxy.server.host_port_pair().port(); + uint16 port = 0; + if (proxy.server.is_valid()) + port = proxy.server.host_port_pair().port(); if (host.length() == 0 && port == 0) return net::ProxyServer(); net::HostPortPair host_port_pair(host, port); @@ -293,7 +295,9 @@ net::ProxyServer ProxyCrosSettingsProvider::CreateProxyServerFromPort( uint16 port, const ProxyConfigServiceImpl::ProxyConfig::ManualProxy& proxy, net::ProxyServer::Scheme scheme) const { - std::string host = proxy.server.host_port_pair().host(); + std::string host; + if (proxy.server.is_valid()) + host = proxy.server.host_port_pair().host(); if (host.length() == 0 && port == 0) return net::ProxyServer(); net::HostPortPair host_port_pair(host, port); diff --git a/net/proxy/proxy_bypass_rules.cc b/net/proxy/proxy_bypass_rules.cc index 91c6f44..dde3d8f 100644 --- a/net/proxy/proxy_bypass_rules.cc +++ b/net/proxy/proxy_bypass_rules.cc @@ -1,4 +1,4 @@ -// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. @@ -219,6 +219,17 @@ bool ProxyBypassRules::AddRuleFromStringUsingSuffixMatching( return AddRuleFromStringInternalWithLogging(raw, true); } +std::string ProxyBypassRules::ToString() const { + std::string result; + for (RuleList::const_iterator rule(rules_.begin()); + rule != rules_.end(); + ++rule) { + result += (*rule)->ToString(); + result += ";"; + } + return result; +} + void ProxyBypassRules::Clear() { STLDeleteElements(&rules_); } diff --git a/net/proxy/proxy_bypass_rules.h b/net/proxy/proxy_bypass_rules.h index ad8afdc..c0f5df3 100644 --- a/net/proxy/proxy_bypass_rules.h +++ b/net/proxy/proxy_bypass_rules.h @@ -1,4 +1,4 @@ -// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. @@ -153,6 +153,10 @@ class ProxyBypassRules { // NOTE: Use AddRuleFromString() unless you truly need this behavior. bool AddRuleFromStringUsingSuffixMatching(const std::string& raw); + // Converts the rules to string representation. Inverse operation to + // ParseFromString(). + std::string ToString() const; + // Removes all the rules. void Clear(); |