Update component updater configurator to match chrome (issue #1950)
This commit is contained in:
parent
1ee311fa45
commit
cf4a50b116
|
@ -5,91 +5,16 @@
|
||||||
#include "libcef/browser/component_updater/cef_component_updater_configurator.h"
|
#include "libcef/browser/component_updater/cef_component_updater_configurator.h"
|
||||||
#include "include/cef_version.h"
|
#include "include/cef_version.h"
|
||||||
|
|
||||||
#include <algorithm>
|
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include "base/command_line.h"
|
|
||||||
#include "base/compiler_specific.h"
|
|
||||||
#include "base/strings/stringprintf.h"
|
|
||||||
#include "base/strings/string_split.h"
|
|
||||||
#include "base/strings/string_util.h"
|
|
||||||
#include "base/version.h"
|
#include "base/version.h"
|
||||||
#include "build/build_config.h"
|
#include "components/component_updater/configurator_impl.h"
|
||||||
#include "chrome/browser/update_client/chrome_update_query_params_delegate.h"
|
|
||||||
#include "components/update_client/component_patcher_operation.h"
|
#include "components/update_client/component_patcher_operation.h"
|
||||||
#include "components/component_updater/component_updater_switches.h"
|
|
||||||
#include "components/component_updater/component_updater_url_constants.h"
|
|
||||||
#include "components/update_client/configurator.h"
|
|
||||||
#include "content/public/browser/browser_thread.h"
|
#include "content/public/browser/browser_thread.h"
|
||||||
#include "net/url_request/url_request_context_getter.h"
|
|
||||||
#include "url/gurl.h"
|
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
|
||||||
#include "base/win/win_util.h"
|
|
||||||
#endif // OS_WIN
|
|
||||||
|
|
||||||
using update_client::Configurator;
|
|
||||||
|
|
||||||
namespace component_updater {
|
namespace component_updater {
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
// Default time constants.
|
class CefConfigurator : public update_client::Configurator {
|
||||||
const int kDelayOneMinute = 60;
|
|
||||||
const int kDelayOneHour = kDelayOneMinute * 60;
|
|
||||||
|
|
||||||
// Debug values you can pass to --component-updater=value1,value2.
|
|
||||||
// Speed up component checking.
|
|
||||||
const char kSwitchFastUpdate[] = "fast-update";
|
|
||||||
|
|
||||||
// Add "testrequest=1" attribute to the update check request.
|
|
||||||
const char kSwitchRequestParam[] = "test-request";
|
|
||||||
|
|
||||||
// Disables pings. Pings are the requests sent to the update server that report
|
|
||||||
// the success or the failure of component install or update attempts.
|
|
||||||
extern const char kSwitchDisablePings[] = "disable-pings";
|
|
||||||
|
|
||||||
// Sets the URL for updates.
|
|
||||||
const char kSwitchUrlSource[] = "url-source";
|
|
||||||
|
|
||||||
// Disables differential updates.
|
|
||||||
const char kSwitchDisableDeltaUpdates[] = "disable-delta-updates";
|
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
|
||||||
// Disables background downloads.
|
|
||||||
const char kSwitchDisableBackgroundDownloads[] = "disable-background-downloads";
|
|
||||||
#endif // defined(OS_WIN)
|
|
||||||
|
|
||||||
// Returns true if and only if |test| is contained in |vec|.
|
|
||||||
bool HasSwitchValue(const std::vector<std::string>& vec, const char* test) {
|
|
||||||
if (vec.empty())
|
|
||||||
return 0;
|
|
||||||
return (std::find(vec.begin(), vec.end(), test) != vec.end());
|
|
||||||
}
|
|
||||||
|
|
||||||
// If there is an element of |vec| of the form |test|=.*, returns the right-
|
|
||||||
// hand side of that assignment. Otherwise, returns an empty string.
|
|
||||||
// The right-hand side may contain additional '=' characters, allowing for
|
|
||||||
// further nesting of switch arguments.
|
|
||||||
std::string GetSwitchArgument(const std::vector<std::string>& vec,
|
|
||||||
const char* test) {
|
|
||||||
if (vec.empty())
|
|
||||||
return std::string();
|
|
||||||
for (std::vector<std::string>::const_iterator it = vec.begin();
|
|
||||||
it != vec.end();
|
|
||||||
++it) {
|
|
||||||
const std::size_t found = it->find("=");
|
|
||||||
if (found != std::string::npos) {
|
|
||||||
if (it->substr(0, found) == test) {
|
|
||||||
return it->substr(found + 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return std::string();
|
|
||||||
}
|
|
||||||
|
|
||||||
class CefConfigurator : public Configurator {
|
|
||||||
public:
|
public:
|
||||||
CefConfigurator(const base::CommandLine* cmdline,
|
CefConfigurator(const base::CommandLine* cmdline,
|
||||||
net::URLRequestContextGetter* url_request_getter,
|
net::URLRequestContextGetter* url_request_getter,
|
||||||
|
@ -124,134 +49,68 @@ class CefConfigurator : public Configurator {
|
||||||
|
|
||||||
~CefConfigurator() override {}
|
~CefConfigurator() override {}
|
||||||
|
|
||||||
net::URLRequestContextGetter* url_request_getter_;
|
ConfiguratorImpl configurator_impl_;
|
||||||
PrefService* pref_service_;
|
PrefService* pref_service_;
|
||||||
std::string extra_info_;
|
|
||||||
GURL url_source_override_;
|
|
||||||
bool fast_update_;
|
|
||||||
bool pings_enabled_;
|
|
||||||
bool deltas_enabled_;
|
|
||||||
bool background_downloads_enabled_;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
CefConfigurator::CefConfigurator(
|
CefConfigurator::CefConfigurator(
|
||||||
const base::CommandLine* cmdline,
|
const base::CommandLine* cmdline,
|
||||||
net::URLRequestContextGetter* url_request_getter,
|
net::URLRequestContextGetter* url_request_getter,
|
||||||
PrefService* pref_service)
|
PrefService* pref_service)
|
||||||
: url_request_getter_(url_request_getter),
|
: configurator_impl_(cmdline, url_request_getter, false),
|
||||||
pref_service_(pref_service),
|
pref_service_(pref_service) {
|
||||||
fast_update_(false),
|
|
||||||
pings_enabled_(false),
|
|
||||||
deltas_enabled_(false),
|
|
||||||
background_downloads_enabled_(false) {
|
|
||||||
// Parse comma-delimited debug flags.
|
|
||||||
std::vector<std::string> switch_values = base::SplitString(
|
|
||||||
cmdline->GetSwitchValueASCII(switches::kComponentUpdater),
|
|
||||||
",", base::KEEP_WHITESPACE, base::SPLIT_WANT_NONEMPTY);
|
|
||||||
fast_update_ = HasSwitchValue(switch_values, kSwitchFastUpdate);
|
|
||||||
pings_enabled_ = !HasSwitchValue(switch_values, kSwitchDisablePings);
|
|
||||||
deltas_enabled_ = !HasSwitchValue(switch_values, kSwitchDisableDeltaUpdates);
|
|
||||||
|
|
||||||
// TODO(dberger): Pull this (and possibly the various hard-coded
|
|
||||||
// delay params in this file) from cef settings.
|
|
||||||
fast_update_ = true;
|
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
|
||||||
background_downloads_enabled_ =
|
|
||||||
!HasSwitchValue(switch_values, kSwitchDisableBackgroundDownloads);
|
|
||||||
#else
|
|
||||||
background_downloads_enabled_ = false;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
const std::string switch_url_source =
|
|
||||||
GetSwitchArgument(switch_values, kSwitchUrlSource);
|
|
||||||
if (!switch_url_source.empty()) {
|
|
||||||
url_source_override_ = GURL(switch_url_source);
|
|
||||||
DCHECK(url_source_override_.is_valid());
|
|
||||||
}
|
|
||||||
|
|
||||||
if (HasSwitchValue(switch_values, kSwitchRequestParam))
|
|
||||||
extra_info_ += "testrequest=\"1\"";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int CefConfigurator::InitialDelay() const {
|
int CefConfigurator::InitialDelay() const {
|
||||||
return fast_update_ ? 10 : (6 * kDelayOneMinute);
|
return configurator_impl_.InitialDelay();
|
||||||
}
|
}
|
||||||
|
|
||||||
int CefConfigurator::NextCheckDelay() const {
|
int CefConfigurator::NextCheckDelay() const {
|
||||||
return fast_update_ ? 60 : (6 * kDelayOneHour);
|
return configurator_impl_.NextCheckDelay();
|
||||||
}
|
}
|
||||||
|
|
||||||
int CefConfigurator::StepDelay() const {
|
int CefConfigurator::StepDelay() const {
|
||||||
return fast_update_ ? 1 : 1;
|
return configurator_impl_.StepDelay();
|
||||||
}
|
}
|
||||||
|
|
||||||
int CefConfigurator::OnDemandDelay() const {
|
int CefConfigurator::OnDemandDelay() const {
|
||||||
return fast_update_ ? 2 : (30 * kDelayOneMinute);
|
return configurator_impl_.OnDemandDelay();
|
||||||
}
|
}
|
||||||
|
|
||||||
int CefConfigurator::UpdateDelay() const {
|
int CefConfigurator::UpdateDelay() const {
|
||||||
return fast_update_ ? 10 : (15 * kDelayOneMinute);
|
return configurator_impl_.UpdateDelay();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<GURL> CefConfigurator::UpdateUrl() const {
|
std::vector<GURL> CefConfigurator::UpdateUrl() const {
|
||||||
std::vector<GURL> urls;
|
return configurator_impl_.UpdateUrl();
|
||||||
if (url_source_override_.is_valid()) {
|
|
||||||
urls.push_back(GURL(url_source_override_));
|
|
||||||
} else {
|
|
||||||
urls.push_back(GURL(kUpdaterDefaultUrl));
|
|
||||||
}
|
|
||||||
return urls;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<GURL> CefConfigurator::PingUrl() const {
|
std::vector<GURL> CefConfigurator::PingUrl() const {
|
||||||
return pings_enabled_ ? UpdateUrl() : std::vector<GURL>();
|
return configurator_impl_.PingUrl();
|
||||||
}
|
}
|
||||||
|
|
||||||
base::Version CefConfigurator::GetBrowserVersion() const {
|
base::Version CefConfigurator::GetBrowserVersion() const {
|
||||||
return base::Version(base::StringPrintf("%d.%d.%d.%d",
|
return configurator_impl_.GetBrowserVersion();
|
||||||
CHROME_VERSION_MAJOR,
|
|
||||||
CHROME_VERSION_MINOR,
|
|
||||||
CHROME_VERSION_BUILD,
|
|
||||||
CHROME_VERSION_PATCH));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string CefConfigurator::GetChannel() const {
|
std::string CefConfigurator::GetChannel() const {
|
||||||
return "";
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string CefConfigurator::GetBrand() const {
|
std::string CefConfigurator::GetBrand() const {
|
||||||
return "";
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string CefConfigurator::GetLang() const {
|
std::string CefConfigurator::GetLang() const {
|
||||||
return "";
|
return std::string();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string CefConfigurator::GetOSLongName() const {
|
std::string CefConfigurator::GetOSLongName() const {
|
||||||
#if defined(OS_WIN)
|
return configurator_impl_.GetOSLongName();
|
||||||
return "Windows";
|
|
||||||
#elif defined(OS_MACOSX)
|
|
||||||
return "Mac OS X";
|
|
||||||
#elif defined(OS_CHROMEOS)
|
|
||||||
return "Chromium OS";
|
|
||||||
#elif defined(OS_ANDROID)
|
|
||||||
return "Android";
|
|
||||||
#elif defined(OS_LINUX)
|
|
||||||
return "Linux";
|
|
||||||
#elif defined(OS_FREEBSD)
|
|
||||||
return "FreeBSD";
|
|
||||||
#elif defined(OS_OPENBSD)
|
|
||||||
return "OpenBSD";
|
|
||||||
#elif defined(OS_SOLARIS)
|
|
||||||
return "Solaris";
|
|
||||||
#else
|
|
||||||
return "Unknown";
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string CefConfigurator::ExtraRequestParams() const {
|
std::string CefConfigurator::ExtraRequestParams() const {
|
||||||
return extra_info_;
|
return configurator_impl_.ExtraRequestParams();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string CefConfigurator::GetDownloadPreference() const {
|
std::string CefConfigurator::GetDownloadPreference() const {
|
||||||
|
@ -259,32 +118,36 @@ std::string CefConfigurator::GetDownloadPreference() const {
|
||||||
}
|
}
|
||||||
|
|
||||||
net::URLRequestContextGetter* CefConfigurator::RequestContext() const {
|
net::URLRequestContextGetter* CefConfigurator::RequestContext() const {
|
||||||
return url_request_getter_;
|
return configurator_impl_.RequestContext();
|
||||||
}
|
}
|
||||||
|
|
||||||
scoped_refptr<update_client::OutOfProcessPatcher>
|
scoped_refptr<update_client::OutOfProcessPatcher>
|
||||||
CefConfigurator::CreateOutOfProcessPatcher() const {
|
CefConfigurator::CreateOutOfProcessPatcher() const {
|
||||||
return NULL;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CefConfigurator::DeltasEnabled() const {
|
bool CefConfigurator::DeltasEnabled() const {
|
||||||
return deltas_enabled_;
|
return configurator_impl_.DeltasEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CefConfigurator::UseBackgroundDownloader() const {
|
bool CefConfigurator::UseBackgroundDownloader() const {
|
||||||
return background_downloads_enabled_;
|
return configurator_impl_.UseBackgroundDownloader();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CefConfigurator::UseCupSigning() const {
|
bool CefConfigurator::UseCupSigning() const {
|
||||||
return true;
|
return configurator_impl_.UseCupSigning();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Returns a task runner to run blocking tasks. The task runner continues to run
|
||||||
|
// after the browser shuts down, until the OS terminates the process. This
|
||||||
|
// imposes certain requirements for the code using the task runner, such as
|
||||||
|
// not accessing any global browser state while the code is running.
|
||||||
scoped_refptr<base::SequencedTaskRunner>
|
scoped_refptr<base::SequencedTaskRunner>
|
||||||
CefConfigurator::GetSequencedTaskRunner() const {
|
CefConfigurator::GetSequencedTaskRunner() const {
|
||||||
return content::BrowserThread::GetBlockingPool()
|
return content::BrowserThread::GetBlockingPool()
|
||||||
->GetSequencedTaskRunnerWithShutdownBehavior(
|
->GetSequencedTaskRunnerWithShutdownBehavior(
|
||||||
base::SequencedWorkerPool::GetSequenceToken(),
|
base::SequencedWorkerPool::GetSequenceToken(),
|
||||||
base::SequencedWorkerPool::SKIP_ON_SHUTDOWN);
|
base::SequencedWorkerPool::CONTINUE_ON_SHUTDOWN);
|
||||||
}
|
}
|
||||||
|
|
||||||
PrefService* CefConfigurator::GetPrefService() const {
|
PrefService* CefConfigurator::GetPrefService() const {
|
||||||
|
|
Loading…
Reference in New Issue