| Index: chrome/browser/services/gcm/gcm_desktop_utils.cc
|
| diff --git a/chrome/browser/services/gcm/gcm_desktop_utils.cc b/chrome/browser/services/gcm/gcm_desktop_utils.cc
|
| index cd7fb73d5466a54a5e7f55f846ffb6fbe649e979..b15dd9f78790906ab2c428946f7ec3248a845fca 100644
|
| --- a/chrome/browser/services/gcm/gcm_desktop_utils.cc
|
| +++ b/chrome/browser/services/gcm/gcm_desktop_utils.cc
|
| @@ -4,15 +4,86 @@
|
|
|
| #include "chrome/browser/services/gcm/gcm_desktop_utils.h"
|
|
|
| +#include "base/command_line.h"
|
| #include "base/sequenced_task_runner.h"
|
| #include "base/threading/sequenced_worker_pool.h"
|
| -#include "chrome/common/gcm_desktop_util.h"
|
| +#include "chrome/browser/services/gcm/gcm_desktop_utils.h"
|
| +#include "chrome/common/channel_info.h"
|
| +#include "chrome/common/sync_util.h"
|
| #include "components/gcm_driver/gcm_client_factory.h"
|
| #include "components/gcm_driver/gcm_driver.h"
|
| +#include "components/gcm_driver/gcm_driver_desktop.h"
|
| +#include "components/version_info/version_info.h"
|
| #include "content/public/browser/browser_thread.h"
|
| +#include "url/gurl.h"
|
|
|
| namespace gcm {
|
|
|
| +namespace {
|
| +
|
| +const char kChannelStatusRelativePath[] = "/experimentstatus";
|
| +
|
| +GCMClient::ChromePlatform GetPlatform() {
|
| +#if defined(OS_WIN)
|
| + return GCMClient::PLATFORM_WIN;
|
| +#elif defined(OS_MACOSX)
|
| + return GCMClient::PLATFORM_MAC;
|
| +#elif defined(OS_IOS)
|
| + return GCMClient::PLATFORM_IOS;
|
| +#elif defined(OS_ANDROID)
|
| + return GCMClient::PLATFORM_ANDROID;
|
| +#elif defined(OS_CHROMEOS)
|
| + return GCMClient::PLATFORM_CROS;
|
| +#elif defined(OS_LINUX)
|
| + return GCMClient::PLATFORM_LINUX;
|
| +#else
|
| + // For all other platforms, return as LINUX.
|
| + return GCMClient::PLATFORM_LINUX;
|
| +#endif
|
| +}
|
| +
|
| +GCMClient::ChromeChannel GetChannel() {
|
| + version_info::Channel channel = chrome::GetChannel();
|
| + switch (channel) {
|
| + case version_info::Channel::UNKNOWN:
|
| + return GCMClient::CHANNEL_UNKNOWN;
|
| + case version_info::Channel::CANARY:
|
| + return GCMClient::CHANNEL_CANARY;
|
| + case version_info::Channel::DEV:
|
| + return GCMClient::CHANNEL_DEV;
|
| + case version_info::Channel::BETA:
|
| + return GCMClient::CHANNEL_BETA;
|
| + case version_info::Channel::STABLE:
|
| + return GCMClient::CHANNEL_STABLE;
|
| + default:
|
| + NOTREACHED();
|
| + return GCMClient::CHANNEL_UNKNOWN;
|
| + }
|
| +}
|
| +
|
| +std::string GetVersion() {
|
| + return version_info::GetVersionNumber();
|
| +}
|
| +
|
| +GCMClient::ChromeBuildInfo GetChromeBuildInfo() {
|
| + GCMClient::ChromeBuildInfo chrome_build_info;
|
| + chrome_build_info.platform = GetPlatform();
|
| + chrome_build_info.channel = GetChannel();
|
| + chrome_build_info.version = GetVersion();
|
| + return chrome_build_info;
|
| +}
|
| +
|
| +std::string GetChannelStatusRequestUrl() {
|
| + GURL sync_url(GetSyncServiceURL(*base::CommandLine::ForCurrentProcess()));
|
| + return sync_url.spec() + kChannelStatusRelativePath;
|
| +}
|
| +
|
| +std::string GetUserAgent() {
|
| + return MakeDesktopUserAgentForSync();
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| scoped_ptr<GCMDriver> CreateGCMDriverDesktop(
|
| scoped_ptr<GCMClientFactory> gcm_client_factory,
|
| PrefService* prefs,
|
| @@ -26,8 +97,11 @@ scoped_ptr<GCMDriver> CreateGCMDriverDesktop(
|
| worker_pool->GetSequenceToken(),
|
| base::SequencedWorkerPool::SKIP_ON_SHUTDOWN));
|
|
|
| - return CreateGCMDriverDesktopWithTaskRunners(
|
| + return scoped_ptr<GCMDriver>(new GCMDriverDesktop(
|
| gcm_client_factory.Pass(),
|
| + GetChromeBuildInfo(),
|
| + GetChannelStatusRequestUrl(),
|
| + GetUserAgent(),
|
| prefs,
|
| store_path,
|
| request_context,
|
| @@ -35,7 +109,7 @@ scoped_ptr<GCMDriver> CreateGCMDriverDesktop(
|
| content::BrowserThread::UI),
|
| content::BrowserThread::GetMessageLoopProxyForThread(
|
| content::BrowserThread::IO),
|
| - blocking_task_runner);
|
| + blocking_task_runner));
|
| }
|
|
|
| } // namespace gcm
|
|
|