blob: b5304bea24fd59fe44f2c8192528c5eee790e4c4 [file] [log] [blame]
// 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.
#include "components/proxy_config/proxy_config_dictionary.h"
#include <memory>
#include <utility>
#include "base/logging.h"
#include "net/proxy_resolution/proxy_config.h"
namespace {
// Integer to specify the type of proxy settings.
// See ProxyPrefs for possible values and interactions with the other proxy
// preferences.
const char kProxyMode[] = "mode";
// String specifying the proxy server. For a specification of the expected
// syntax see net::ProxyConfig::ProxyRules::ParseFromString().
const char kProxyServer[] = "server";
// URL to the proxy .pac file.
const char kProxyPacUrl[] = "pac_url";
// Optional boolean flag indicating whether a valid PAC script is mandatory.
// If true, network traffic does not fall back to direct connections in case the
// PAC script is not available.
const char kProxyPacMandatory[] = "pac_mandatory";
// String containing proxy bypass rules. For a specification of the
// expected syntax see net::ProxyBypassRules::ParseFromString().
const char kProxyBypassList[] = "bypass_list";
} // namespace
ProxyConfigDictionary::ProxyConfigDictionary(base::Value dict)
: dict_(std::move(dict)) {
DCHECK(dict_.is_dict());
}
ProxyConfigDictionary::~ProxyConfigDictionary() {}
bool ProxyConfigDictionary::GetMode(ProxyPrefs::ProxyMode* out) const {
const base::Value* mode_value = dict_.FindKey(kProxyMode);
if (!mode_value || !mode_value->is_string())
return false;
std::string mode_str = mode_value->GetString();
return StringToProxyMode(mode_str, out);
}
bool ProxyConfigDictionary::GetPacUrl(std::string* out) const {
return GetString(kProxyPacUrl, out);
}
bool ProxyConfigDictionary::GetPacMandatory(bool* out) const {
const base::Value* value = dict_.FindKey(kProxyPacMandatory);
if (!value || !value->is_bool()) {
*out = false;
return false;
}
*out = value->GetBool();
return true;
}
bool ProxyConfigDictionary::GetProxyServer(std::string* out) const {
return GetString(kProxyServer, out);
}
bool ProxyConfigDictionary::GetBypassList(std::string* out) const {
return GetString(kProxyBypassList, out);
}
bool ProxyConfigDictionary::HasBypassList() const {
return dict_.FindKey(kProxyBypassList);
}
const base::Value& ProxyConfigDictionary::GetDictionary() const {
return dict_;
}
// static
base::Value ProxyConfigDictionary::CreateDirect() {
return CreateDictionary(ProxyPrefs::MODE_DIRECT, std::string(), false,
std::string(), std::string());
}
// static
base::Value ProxyConfigDictionary::CreateAutoDetect() {
return CreateDictionary(ProxyPrefs::MODE_AUTO_DETECT, std::string(), false,
std::string(), std::string());
}
// static
base::Value ProxyConfigDictionary::CreatePacScript(const std::string& pac_url,
bool pac_mandatory) {
return CreateDictionary(ProxyPrefs::MODE_PAC_SCRIPT, pac_url, pac_mandatory,
std::string(), std::string());
}
// static
base::Value ProxyConfigDictionary::CreateFixedServers(
const std::string& proxy_server,
const std::string& bypass_list) {
if (!proxy_server.empty()) {
return CreateDictionary(ProxyPrefs::MODE_FIXED_SERVERS, std::string(),
false, proxy_server, bypass_list);
} else {
return CreateDirect();
}
}
// static
base::Value ProxyConfigDictionary::CreateSystem() {
return CreateDictionary(ProxyPrefs::MODE_SYSTEM, std::string(), false,
std::string(), std::string());
}
// static
base::Value ProxyConfigDictionary::CreateDictionary(
ProxyPrefs::ProxyMode mode,
const std::string& pac_url,
bool pac_mandatory,
const std::string& proxy_server,
const std::string& bypass_list) {
base::Value dict(base::Value::Type::DICTIONARY);
dict.SetKey(kProxyMode, base::Value(ProxyModeToString(mode)));
if (!pac_url.empty()) {
dict.SetKey(kProxyPacUrl, base::Value(pac_url));
dict.SetKey(kProxyPacMandatory, base::Value(pac_mandatory));
}
if (!proxy_server.empty())
dict.SetKey(kProxyServer, base::Value(proxy_server));
if (!bypass_list.empty())
dict.SetKey(kProxyBypassList, base::Value(bypass_list));
return dict;
}
// static
void ProxyConfigDictionary::EncodeAndAppendProxyServer(
const std::string& url_scheme,
const net::ProxyServer& server,
std::string* spec) {
if (!server.is_valid())
return;
if (!spec->empty())
*spec += ';';
if (!url_scheme.empty()) {
*spec += url_scheme;
*spec += "=";
}
*spec += server.ToURI();
}
bool ProxyConfigDictionary::GetString(const char* key, std::string* out) const {
const base::Value* value = dict_.FindKey(key);
if (!value || !value->is_string()) {
*out = "";
return false;
}
*out = value->GetString();
return true;
}