| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "components/gcm_driver/gcm_driver_desktop.h" | 5 #include "components/gcm_driver/gcm_driver_desktop.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 84 void SetAccountTokens( | 84 void SetAccountTokens( |
| 85 const std::vector<GCMClient::AccountTokenInfo>& account_tokens); | 85 const std::vector<GCMClient::AccountTokenInfo>& account_tokens); |
| 86 void UpdateAccountMapping(const AccountMapping& account_mapping); | 86 void UpdateAccountMapping(const AccountMapping& account_mapping); |
| 87 void RemoveAccountMapping(const std::string& account_id); | 87 void RemoveAccountMapping(const std::string& account_id); |
| 88 void SetLastTokenFetchTime(const base::Time& time); | 88 void SetLastTokenFetchTime(const base::Time& time); |
| 89 void WakeFromSuspendForHeartbeat(bool wake); | 89 void WakeFromSuspendForHeartbeat(bool wake); |
| 90 void AddInstanceIDData(const std::string& app_id, | 90 void AddInstanceIDData(const std::string& app_id, |
| 91 const std::string& instance_id_data); | 91 const std::string& instance_id_data); |
| 92 void RemoveInstanceIDData(const std::string& app_id); | 92 void RemoveInstanceIDData(const std::string& app_id); |
| 93 void GetInstanceIDData(const std::string& app_id); | 93 void GetInstanceIDData(const std::string& app_id); |
| 94 void AddHeartbeatInterval(const std::string& scope, int interval_ms); |
| 95 void RemoveHeartbeatInterval(const std::string& scope); |
| 94 | 96 |
| 95 // For testing purpose. Can be called from UI thread. Use with care. | 97 // For testing purpose. Can be called from UI thread. Use with care. |
| 96 GCMClient* gcm_client_for_testing() const { return gcm_client_.get(); } | 98 GCMClient* gcm_client_for_testing() const { return gcm_client_.get(); } |
| 97 | 99 |
| 98 private: | 100 private: |
| 99 scoped_refptr<base::SequencedTaskRunner> ui_thread_; | 101 scoped_refptr<base::SequencedTaskRunner> ui_thread_; |
| 100 scoped_refptr<base::SequencedTaskRunner> io_thread_; | 102 scoped_refptr<base::SequencedTaskRunner> io_thread_; |
| 101 | 103 |
| 102 base::WeakPtr<GCMDriverDesktop> service_; | 104 base::WeakPtr<GCMDriverDesktop> service_; |
| 103 | 105 |
| (...skipping 281 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 385 scoped_ptr<base::Timer> timer; | 387 scoped_ptr<base::Timer> timer; |
| 386 if (wake) | 388 if (wake) |
| 387 timer.reset(new timers::SimpleAlarmTimer()); | 389 timer.reset(new timers::SimpleAlarmTimer()); |
| 388 else | 390 else |
| 389 timer.reset(new base::Timer(true, false)); | 391 timer.reset(new base::Timer(true, false)); |
| 390 | 392 |
| 391 gcm_client_->UpdateHeartbeatTimer(timer.Pass()); | 393 gcm_client_->UpdateHeartbeatTimer(timer.Pass()); |
| 392 #endif | 394 #endif |
| 393 } | 395 } |
| 394 | 396 |
| 397 void GCMDriverDesktop::IOWorker::AddHeartbeatInterval(const std::string& scope, |
| 398 int interval_ms) { |
| 399 DCHECK(io_thread_->RunsTasksOnCurrentThread()); |
| 400 gcm_client_->AddHeartbeatInterval(scope, interval_ms); |
| 401 } |
| 402 |
| 403 void GCMDriverDesktop::IOWorker::RemoveHeartbeatInterval( |
| 404 const std::string& scope) { |
| 405 DCHECK(io_thread_->RunsTasksOnCurrentThread()); |
| 406 gcm_client_->RemoveHeartbeatInterval(scope); |
| 407 } |
| 408 |
| 395 GCMDriverDesktop::GCMDriverDesktop( | 409 GCMDriverDesktop::GCMDriverDesktop( |
| 396 scoped_ptr<GCMClientFactory> gcm_client_factory, | 410 scoped_ptr<GCMClientFactory> gcm_client_factory, |
| 397 const GCMClient::ChromeBuildInfo& chrome_build_info, | 411 const GCMClient::ChromeBuildInfo& chrome_build_info, |
| 398 const std::string& channel_status_request_url, | 412 const std::string& channel_status_request_url, |
| 399 const std::string& user_agent, | 413 const std::string& user_agent, |
| 400 PrefService* prefs, | 414 PrefService* prefs, |
| 401 const base::FilePath& store_path, | 415 const base::FilePath& store_path, |
| 402 const scoped_refptr<net::URLRequestContextGetter>& request_context, | 416 const scoped_refptr<net::URLRequestContextGetter>& request_context, |
| 403 const scoped_refptr<base::SequencedTaskRunner>& ui_thread, | 417 const scoped_refptr<base::SequencedTaskRunner>& ui_thread, |
| 404 const scoped_refptr<base::SequencedTaskRunner>& io_thread, | 418 const scoped_refptr<base::SequencedTaskRunner>& io_thread, |
| (...skipping 356 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 761 | 775 |
| 762 // The GCMClient is ready so we can go ahead and post this task to the | 776 // The GCMClient is ready so we can go ahead and post this task to the |
| 763 // IOWorker. | 777 // IOWorker. |
| 764 io_thread_->PostTask( | 778 io_thread_->PostTask( |
| 765 FROM_HERE, | 779 FROM_HERE, |
| 766 base::Bind(&GCMDriverDesktop::IOWorker::WakeFromSuspendForHeartbeat, | 780 base::Bind(&GCMDriverDesktop::IOWorker::WakeFromSuspendForHeartbeat, |
| 767 base::Unretained(io_worker_.get()), | 781 base::Unretained(io_worker_.get()), |
| 768 wake_from_suspend_enabled_)); | 782 wake_from_suspend_enabled_)); |
| 769 } | 783 } |
| 770 | 784 |
| 785 void GCMDriverDesktop::AddHeartbeatInterval(const std::string& scope, |
| 786 int interval_ms) { |
| 787 DCHECK(ui_thread_->RunsTasksOnCurrentThread()); |
| 788 |
| 789 // The GCM service has not been initialized. |
| 790 if (!delayed_task_controller_) |
| 791 return; |
| 792 |
| 793 if (!delayed_task_controller_->CanRunTaskWithoutDelay()) { |
| 794 // The GCM service was initialized but has not started yet. |
| 795 delayed_task_controller_->AddTask( |
| 796 base::Bind(&GCMDriverDesktop::AddHeartbeatInterval, |
| 797 weak_ptr_factory_.GetWeakPtr(), scope, interval_ms)); |
| 798 return; |
| 799 } |
| 800 |
| 801 io_thread_->PostTask( |
| 802 FROM_HERE, |
| 803 base::Bind(&GCMDriverDesktop::IOWorker::AddHeartbeatInterval, |
| 804 base::Unretained(io_worker_.get()), scope, interval_ms)); |
| 805 } |
| 806 |
| 807 void GCMDriverDesktop::RemoveHeartbeatInterval(const std::string& scope) { |
| 808 DCHECK(ui_thread_->RunsTasksOnCurrentThread()); |
| 809 |
| 810 // The GCM service has not been initialized. |
| 811 if (!delayed_task_controller_) |
| 812 return; |
| 813 |
| 814 if (!delayed_task_controller_->CanRunTaskWithoutDelay()) { |
| 815 // The GCM service was initialized but has not started yet. |
| 816 delayed_task_controller_->AddTask( |
| 817 base::Bind(&GCMDriverDesktop::RemoveHeartbeatInterval, |
| 818 weak_ptr_factory_.GetWeakPtr(), scope)); |
| 819 return; |
| 820 } |
| 821 |
| 822 io_thread_->PostTask( |
| 823 FROM_HERE, |
| 824 base::Bind(&GCMDriverDesktop::IOWorker::RemoveHeartbeatInterval, |
| 825 base::Unretained(io_worker_.get()), scope)); |
| 826 } |
| 827 |
| 771 void GCMDriverDesktop::SetAccountTokens( | 828 void GCMDriverDesktop::SetAccountTokens( |
| 772 const std::vector<GCMClient::AccountTokenInfo>& account_tokens) { | 829 const std::vector<GCMClient::AccountTokenInfo>& account_tokens) { |
| 773 DCHECK(ui_thread_->RunsTasksOnCurrentThread()); | 830 DCHECK(ui_thread_->RunsTasksOnCurrentThread()); |
| 774 | 831 |
| 775 account_mapper_->SetAccountTokens(account_tokens); | 832 account_mapper_->SetAccountTokens(account_tokens); |
| 776 | 833 |
| 777 io_thread_->PostTask( | 834 io_thread_->PostTask( |
| 778 FROM_HERE, | 835 FROM_HERE, |
| 779 base::Bind(&GCMDriverDesktop::IOWorker::SetAccountTokens, | 836 base::Bind(&GCMDriverDesktop::IOWorker::SetAccountTokens, |
| 780 base::Unretained(io_worker_.get()), | 837 base::Unretained(io_worker_.get()), |
| (...skipping 142 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 923 DCHECK(ui_thread_->RunsTasksOnCurrentThread()); | 980 DCHECK(ui_thread_->RunsTasksOnCurrentThread()); |
| 924 | 981 |
| 925 // Normally request_gcm_statistics_callback_ would not be null. | 982 // Normally request_gcm_statistics_callback_ would not be null. |
| 926 if (!request_gcm_statistics_callback_.is_null()) | 983 if (!request_gcm_statistics_callback_.is_null()) |
| 927 request_gcm_statistics_callback_.Run(stats); | 984 request_gcm_statistics_callback_.Run(stats); |
| 928 else | 985 else |
| 929 LOG(WARNING) << "request_gcm_statistics_callback_ is NULL."; | 986 LOG(WARNING) << "request_gcm_statistics_callback_ is NULL."; |
| 930 } | 987 } |
| 931 | 988 |
| 932 } // namespace gcm | 989 } // namespace gcm |
| OLD | NEW |