| 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/copresence/rpc/rpc_handler.h" | 5 #include "components/copresence/rpc/rpc_handler.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
| 9 #include "base/guid.h" | 9 #include "base/guid.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| 11 #include "base/strings/string_util.h" | 11 #include "base/strings/string_util.h" |
| 12 #include "base/strings/stringprintf.h" | 12 #include "base/strings/stringprintf.h" |
| 13 | 13 |
| 14 // TODO(ckehoe): time.h includes windows.h, which #defines DeviceCapabilities | 14 // TODO(ckehoe): time.h includes windows.h, which #defines DeviceCapabilities |
| 15 // to DeviceCapabilitiesW. This breaks the pb.h headers below. For now, | 15 // to DeviceCapabilitiesW. This breaks the pb.h headers below. For now, |
| 16 // we fix this with an #undef. | 16 // we fix this with an #undef. |
| 17 #include "base/time/time.h" | 17 #include "base/time/time.h" |
| 18 #if defined(OS_WIN) | 18 #if defined(OS_WIN) |
| 19 #undef DeviceCapabilities | 19 #undef DeviceCapabilities |
| 20 #endif | 20 #endif |
| 21 | 21 |
| 22 #include "components/copresence/copresence_state_impl.h" |
| 22 #include "components/copresence/copresence_switches.h" | 23 #include "components/copresence/copresence_switches.h" |
| 23 #include "components/copresence/handlers/directive_handler.h" | 24 #include "components/copresence/handlers/directive_handler.h" |
| 24 #include "components/copresence/handlers/gcm_handler.h" | 25 #include "components/copresence/handlers/gcm_handler.h" |
| 25 #include "components/copresence/proto/codes.pb.h" | 26 #include "components/copresence/proto/codes.pb.h" |
| 26 #include "components/copresence/proto/data.pb.h" | 27 #include "components/copresence/proto/data.pb.h" |
| 27 #include "components/copresence/proto/rpcs.pb.h" | 28 #include "components/copresence/proto/rpcs.pb.h" |
| 28 #include "components/copresence/public/copresence_constants.h" | 29 #include "components/copresence/public/copresence_constants.h" |
| 29 #include "components/copresence/public/copresence_delegate.h" | 30 #include "components/copresence/public/copresence_delegate.h" |
| 30 #include "components/copresence/rpc/http_post.h" | 31 #include "components/copresence/rpc/http_post.h" |
| 31 #include "net/http/http_status_code.h" | 32 #include "net/http/http_status_code.h" |
| (...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 158 : AUDIO_ULTRASOUND_PASSBAND); | 159 : AUDIO_ULTRASOUND_PASSBAND); |
| 159 signals->set_observed_time_millis(base::Time::Now().ToJsTime()); | 160 signals->set_observed_time_millis(base::Time::Now().ToJsTime()); |
| 160 } | 161 } |
| 161 | 162 |
| 162 } // namespace | 163 } // namespace |
| 163 | 164 |
| 164 | 165 |
| 165 // Public functions. | 166 // Public functions. |
| 166 | 167 |
| 167 RpcHandler::RpcHandler(CopresenceDelegate* delegate, | 168 RpcHandler::RpcHandler(CopresenceDelegate* delegate, |
| 169 CopresenceStateImpl* state, |
| 168 DirectiveHandler* directive_handler, | 170 DirectiveHandler* directive_handler, |
| 169 GCMHandler* gcm_handler, | 171 GCMHandler* gcm_handler, |
| 170 const PostCallback& server_post_callback) | 172 const PostCallback& server_post_callback) |
| 171 : delegate_(delegate), | 173 : delegate_(delegate), |
| 174 state_(state), |
| 172 directive_handler_(directive_handler), | 175 directive_handler_(directive_handler), |
| 173 gcm_handler_(gcm_handler), | 176 gcm_handler_(gcm_handler), |
| 174 server_post_callback_(server_post_callback), | 177 server_post_callback_(server_post_callback), |
| 175 invalid_audio_token_cache_( | 178 invalid_audio_token_cache_( |
| 176 base::TimeDelta::FromMilliseconds(kInvalidTokenExpiryTimeMs), | 179 base::TimeDelta::FromMilliseconds(kInvalidTokenExpiryTimeMs), |
| 177 kMaxInvalidTokens) { | 180 kMaxInvalidTokens) { |
| 178 DCHECK(delegate_); | 181 DCHECK(delegate_); |
| 179 DCHECK(directive_handler_); | 182 DCHECK(directive_handler_); |
| 180 // |gcm_handler_| is optional. | 183 // |gcm_handler_| is optional. |
| 181 | 184 |
| (...skipping 302 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 484 | 487 |
| 485 if (response.has_update_signals_response()) { | 488 if (response.has_update_signals_response()) { |
| 486 const UpdateSignalsResponse& update_response = | 489 const UpdateSignalsResponse& update_response = |
| 487 response.update_signals_response(); | 490 response.update_signals_response(); |
| 488 DispatchMessages(update_response.message()); | 491 DispatchMessages(update_response.message()); |
| 489 | 492 |
| 490 for (const Directive& directive : update_response.directive()) | 493 for (const Directive& directive : update_response.directive()) |
| 491 directive_handler_->AddDirective(directive); | 494 directive_handler_->AddDirective(directive); |
| 492 | 495 |
| 493 for (const Token& token : update_response.token()) { | 496 for (const Token& token : update_response.token()) { |
| 497 state_->UpdateTokenStatus(token.id(), token.status()); |
| 494 switch (token.status()) { | 498 switch (token.status()) { |
| 495 case VALID: | 499 case VALID: |
| 496 // TODO(rkc/ckehoe): Store the token in a |valid_token_cache_| with a | 500 // TODO(rkc/ckehoe): Store the token in a |valid_token_cache_| with a |
| 497 // short TTL (like 10s) and send it up with every report request. | 501 // short TTL (like 10s) and send it up with every report request. |
| 498 // Then we'll still get messages while we're waiting to hear it again. | 502 // Then we'll still get messages while we're waiting to hear it again. |
| 499 VLOG(1) << "Got valid token " << token.id(); | 503 VLOG(1) << "Got valid token " << token.id(); |
| 500 break; | 504 break; |
| 501 case INVALID: | 505 case INVALID: |
| 502 DVLOG(3) << "Discarding invalid token " << token.id(); | 506 DVLOG(3) << "Discarding invalid token " << token.id(); |
| 503 invalid_audio_token_cache_.Add(token.id(), true); | 507 invalid_audio_token_cache_.Add(token.id(), true); |
| (...skipping 128 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 632 api_key, | 636 api_key, |
| 633 auth_token, | 637 auth_token, |
| 634 command_line->GetSwitchValueASCII(switches::kCopresenceTracingToken), | 638 command_line->GetSwitchValueASCII(switches::kCopresenceTracingToken), |
| 635 *request_proto); | 639 *request_proto); |
| 636 | 640 |
| 637 http_post->Start(base::Bind(callback, http_post)); | 641 http_post->Start(base::Bind(callback, http_post)); |
| 638 pending_posts_.insert(http_post); | 642 pending_posts_.insert(http_post); |
| 639 } | 643 } |
| 640 | 644 |
| 641 } // namespace copresence | 645 } // namespace copresence |
| OLD | NEW |