mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	Update component updater configurator to match chrome (issue #1950)
This commit is contained in:
		| @@ -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 { | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user