Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "remoting/host/setup/daemon_controller.h" | 5 #include "remoting/host/setup/daemon_controller.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/location.h" | 8 #include "base/location.h" |
| 9 #include "base/single_thread_task_runner.h" | 9 #include "base/single_thread_task_runner.h" |
| 10 #include "base/thread_task_runner_handle.h" | 10 #include "base/thread_task_runner_handle.h" |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 43 DaemonController::GetConfigCallback wrapped_done = base::Bind( | 43 DaemonController::GetConfigCallback wrapped_done = base::Bind( |
| 44 &DaemonController::InvokeConfigCallbackAndScheduleNext, this, done); | 44 &DaemonController::InvokeConfigCallbackAndScheduleNext, this, done); |
| 45 base::Closure request = base::Bind( | 45 base::Closure request = base::Bind( |
| 46 &DaemonController::DoGetConfig, this, wrapped_done); | 46 &DaemonController::DoGetConfig, this, wrapped_done); |
| 47 ServiceOrQueueRequest(request); | 47 ServiceOrQueueRequest(request); |
| 48 } | 48 } |
| 49 | 49 |
| 50 void DaemonController::SetConfigAndStart( | 50 void DaemonController::SetConfigAndStart( |
| 51 scoped_ptr<base::DictionaryValue> config, | 51 scoped_ptr<base::DictionaryValue> config, |
| 52 bool consent, | 52 bool consent, |
| 53 const CompletionCallback& done) { | 53 const base::Closure& on_done, |
| 54 const ErrorCallback& on_error) { | |
| 54 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 55 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 55 | 56 |
| 56 DaemonController::CompletionCallback wrapped_done = base::Bind( | 57 base::Closure wrapped_on_done = base::Bind( |
| 57 &DaemonController::InvokeCompletionCallbackAndScheduleNext, this, done); | 58 &DaemonController::InvokeSuccessCallbackAndScheduleNext, this, on_done); |
| 59 DaemonController::ErrorCallback wrapped_on_error = base::Bind( | |
| 60 &DaemonController::InvokeErrorCallbackAndScheduleNext, this, on_error); | |
|
Sergey Ulanov
2015/08/08 00:57:09
Do we need separate on_done and on_error cases? I
| |
| 58 base::Closure request = base::Bind( | 61 base::Closure request = base::Bind( |
| 59 &DaemonController::DoSetConfigAndStart, this, base::Passed(&config), | 62 &DaemonController::DoSetConfigAndStart, this, base::Passed(&config), |
| 60 consent, wrapped_done); | 63 consent, wrapped_on_done, wrapped_on_error); |
| 61 ServiceOrQueueRequest(request); | 64 ServiceOrQueueRequest(request); |
| 62 } | 65 } |
| 63 | 66 |
| 64 void DaemonController::UpdateConfig(scoped_ptr<base::DictionaryValue> config, | 67 void DaemonController::UpdateConfig(scoped_ptr<base::DictionaryValue> config, |
| 65 const CompletionCallback& done) { | 68 const base::Closure& on_done, |
| 69 const ErrorCallback& on_error) { | |
| 66 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 70 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 67 | 71 |
| 68 DaemonController::CompletionCallback wrapped_done = base::Bind( | 72 base::Closure wrapped_on_done = base::Bind( |
| 69 &DaemonController::InvokeCompletionCallbackAndScheduleNext, this, done); | 73 &DaemonController::InvokeSuccessCallbackAndScheduleNext, this, on_done); |
| 74 DaemonController::ErrorCallback wrapped_on_error = base::Bind( | |
| 75 &DaemonController::InvokeErrorCallbackAndScheduleNext, this, on_error); | |
| 70 base::Closure request = base::Bind( | 76 base::Closure request = base::Bind( |
| 71 &DaemonController::DoUpdateConfig, this, base::Passed(&config), | 77 &DaemonController::DoUpdateConfig, this, base::Passed(&config), |
| 72 wrapped_done); | 78 wrapped_on_done, wrapped_on_error); |
| 73 ServiceOrQueueRequest(request); | 79 ServiceOrQueueRequest(request); |
| 74 } | 80 } |
| 75 | 81 |
| 76 void DaemonController::Stop(const CompletionCallback& done) { | 82 void DaemonController::Stop(const base::Closure& on_done, |
| 83 const ErrorCallback& on_error) { | |
| 77 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 84 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 78 | 85 |
| 79 DaemonController::CompletionCallback wrapped_done = base::Bind( | 86 base::Closure wrapped_on_done = base::Bind( |
| 80 &DaemonController::InvokeCompletionCallbackAndScheduleNext, this, done); | 87 &DaemonController::InvokeSuccessCallbackAndScheduleNext, this, on_done); |
| 88 DaemonController::ErrorCallback wrapped_on_error = base::Bind( | |
| 89 &DaemonController::InvokeErrorCallbackAndScheduleNext, this, on_error); | |
| 81 base::Closure request = base::Bind( | 90 base::Closure request = base::Bind( |
| 82 &DaemonController::DoStop, this, wrapped_done); | 91 &DaemonController::DoStop, this, wrapped_on_done, wrapped_on_error); |
| 83 ServiceOrQueueRequest(request); | 92 ServiceOrQueueRequest(request); |
| 84 } | 93 } |
| 85 | 94 |
| 86 void DaemonController::GetUsageStatsConsent( | 95 void DaemonController::GetUsageStatsConsent( |
| 87 const GetUsageStatsConsentCallback& done) { | 96 const GetUsageStatsConsentCallback& done) { |
| 88 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 97 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 89 | 98 |
| 90 DaemonController::GetUsageStatsConsentCallback wrapped_done = base::Bind( | 99 DaemonController::GetUsageStatsConsentCallback wrapped_done = base::Bind( |
| 91 &DaemonController::InvokeConsentCallbackAndScheduleNext, this, done); | 100 &DaemonController::InvokeConsentCallbackAndScheduleNext, this, done); |
| 92 base::Closure request = base::Bind( | 101 base::Closure request = base::Bind( |
| (...skipping 14 matching lines...) Expand all Loading... | |
| 107 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); | 116 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); |
| 108 | 117 |
| 109 scoped_ptr<base::DictionaryValue> config = delegate_->GetConfig(); | 118 scoped_ptr<base::DictionaryValue> config = delegate_->GetConfig(); |
| 110 caller_task_runner_->PostTask(FROM_HERE, | 119 caller_task_runner_->PostTask(FROM_HERE, |
| 111 base::Bind(done, base::Passed(&config))); | 120 base::Bind(done, base::Passed(&config))); |
| 112 } | 121 } |
| 113 | 122 |
| 114 void DaemonController::DoSetConfigAndStart( | 123 void DaemonController::DoSetConfigAndStart( |
| 115 scoped_ptr<base::DictionaryValue> config, | 124 scoped_ptr<base::DictionaryValue> config, |
| 116 bool consent, | 125 bool consent, |
| 117 const CompletionCallback& done) { | 126 const base::Closure& on_done, |
| 127 const ErrorCallback& on_error) { | |
| 118 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); | 128 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); |
| 119 | 129 |
| 120 delegate_->SetConfigAndStart(config.Pass(), consent, done); | 130 delegate_->SetConfigAndStart(config.Pass(), consent, on_done, on_error); |
| 121 } | 131 } |
| 122 | 132 |
| 123 void DaemonController::DoUpdateConfig( | 133 void DaemonController::DoUpdateConfig( |
| 124 scoped_ptr<base::DictionaryValue> config, | 134 scoped_ptr<base::DictionaryValue> config, |
| 125 const CompletionCallback& done) { | 135 const base::Closure& on_done, |
| 136 const ErrorCallback& on_error) { | |
| 126 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); | 137 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); |
| 127 | 138 |
| 128 delegate_->UpdateConfig(config.Pass(), done); | 139 delegate_->UpdateConfig(config.Pass(), on_done, on_error); |
| 129 } | 140 } |
| 130 | 141 |
| 131 void DaemonController::DoStop(const CompletionCallback& done) { | 142 void DaemonController::DoStop(const base::Closure& on_done, |
| 143 const ErrorCallback& on_error) { | |
| 132 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); | 144 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); |
| 133 | 145 |
| 134 delegate_->Stop(done); | 146 delegate_->Stop(on_done, on_error); |
| 135 } | 147 } |
| 136 | 148 |
| 137 void DaemonController::DoGetUsageStatsConsent( | 149 void DaemonController::DoGetUsageStatsConsent( |
| 138 const GetUsageStatsConsentCallback& done) { | 150 const GetUsageStatsConsentCallback& done) { |
| 139 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); | 151 DCHECK(delegate_task_runner_->BelongsToCurrentThread()); |
| 140 | 152 |
| 141 DaemonController::UsageStatsConsent consent = | 153 DaemonController::UsageStatsConsent consent = |
| 142 delegate_->GetUsageStatsConsent(); | 154 delegate_->GetUsageStatsConsent(); |
| 143 caller_task_runner_->PostTask(FROM_HERE, base::Bind(done, consent)); | 155 caller_task_runner_->PostTask(FROM_HERE, base::Bind(done, consent)); |
| 144 } | 156 } |
| 145 | 157 |
| 146 void DaemonController::InvokeCompletionCallbackAndScheduleNext( | 158 void DaemonController::InvokeSuccessCallbackAndScheduleNext( |
| 147 const CompletionCallback& done, | 159 const base::Closure& callback) { |
| 148 AsyncResult result) { | |
| 149 if (!caller_task_runner_->BelongsToCurrentThread()) { | 160 if (!caller_task_runner_->BelongsToCurrentThread()) { |
| 150 caller_task_runner_->PostTask( | 161 caller_task_runner_->PostTask( |
| 151 FROM_HERE, | 162 FROM_HERE, |
| 152 base::Bind(&DaemonController::InvokeCompletionCallbackAndScheduleNext, | 163 base::Bind(&DaemonController::InvokeSuccessCallbackAndScheduleNext, |
| 153 this, done, result)); | 164 this, callback)); |
| 154 return; | 165 return; |
| 155 } | 166 } |
| 156 | 167 |
| 157 done.Run(result); | 168 callback.Run(); |
| 169 ScheduleNext(); | |
| 170 } | |
| 171 | |
| 172 void DaemonController::InvokeErrorCallbackAndScheduleNext( | |
| 173 const ErrorCallback& callback, | |
| 174 const std::string& error_message, | |
| 175 const tracked_objects::Location& location) { | |
| 176 if (!caller_task_runner_->BelongsToCurrentThread()) { | |
|
Sergey Ulanov
2015/08/08 00:57:09
Delegate interface definition says that the callba
| |
| 177 caller_task_runner_->PostTask( | |
| 178 FROM_HERE, | |
| 179 base::Bind(&DaemonController::InvokeErrorCallbackAndScheduleNext, | |
| 180 this, callback, error_message, location)); | |
| 181 return; | |
| 182 } | |
| 183 | |
| 184 callback.Run(error_message, location); | |
| 158 ScheduleNext(); | 185 ScheduleNext(); |
| 159 } | 186 } |
| 160 | 187 |
| 161 void DaemonController::InvokeConfigCallbackAndScheduleNext( | 188 void DaemonController::InvokeConfigCallbackAndScheduleNext( |
| 162 const GetConfigCallback& done, | 189 const GetConfigCallback& callback, |
| 163 scoped_ptr<base::DictionaryValue> config) { | 190 scoped_ptr<base::DictionaryValue> config) { |
| 164 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 191 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 165 | 192 |
| 166 done.Run(config.Pass()); | 193 callback.Run(config.Pass()); |
| 167 ScheduleNext(); | 194 ScheduleNext(); |
| 168 } | 195 } |
| 169 | 196 |
| 170 void DaemonController::InvokeConsentCallbackAndScheduleNext( | 197 void DaemonController::InvokeConsentCallbackAndScheduleNext( |
| 171 const GetUsageStatsConsentCallback& done, | 198 const GetUsageStatsConsentCallback& callback, |
| 172 const UsageStatsConsent& consent) { | 199 const UsageStatsConsent& consent) { |
| 173 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 200 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 174 | 201 |
| 175 done.Run(consent); | 202 callback.Run(consent); |
| 176 ScheduleNext(); | 203 ScheduleNext(); |
| 177 } | 204 } |
| 178 | 205 |
| 179 void DaemonController::ScheduleNext() { | 206 void DaemonController::ScheduleNext() { |
| 180 DCHECK(caller_task_runner_->BelongsToCurrentThread()); | 207 DCHECK(caller_task_runner_->BelongsToCurrentThread()); |
| 181 | 208 |
| 182 pending_requests_.pop(); | 209 pending_requests_.pop(); |
| 183 ServiceNextRequest(); | 210 ServiceNextRequest(); |
| 184 } | 211 } |
| 185 | 212 |
| 186 void DaemonController::ServiceOrQueueRequest(const base::Closure& request) { | 213 void DaemonController::ServiceOrQueueRequest(const base::Closure& request) { |
| 187 bool servicing_request = !pending_requests_.empty(); | 214 bool servicing_request = !pending_requests_.empty(); |
| 188 pending_requests_.push(request); | 215 pending_requests_.push(request); |
| 189 if (!servicing_request) | 216 if (!servicing_request) |
| 190 ServiceNextRequest(); | 217 ServiceNextRequest(); |
| 191 } | 218 } |
| 192 | 219 |
| 193 void DaemonController::ServiceNextRequest() { | 220 void DaemonController::ServiceNextRequest() { |
| 194 if (!pending_requests_.empty()) | 221 if (!pending_requests_.empty()) |
| 195 delegate_task_runner_->PostTask(FROM_HERE, pending_requests_.front()); | 222 delegate_task_runner_->PostTask(FROM_HERE, pending_requests_.front()); |
| 196 } | 223 } |
| 197 | 224 |
| 198 } // namespace remoting | 225 } // namespace remoting |
| OLD | NEW |