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 #ifndef COMPONENTS_COPRESENCE_RPC_RPC_HANDLER_H_ | 5 #ifndef COMPONENTS_COPRESENCE_RPC_RPC_HANDLER_H_ |
6 #define COMPONENTS_COPRESENCE_RPC_RPC_HANDLER_H_ | 6 #define COMPONENTS_COPRESENCE_RPC_RPC_HANDLER_H_ |
7 | 7 |
| 8 #include <google/protobuf/repeated_field.h> |
| 9 |
| 10 #include <set> |
8 #include <string> | 11 #include <string> |
9 #include <vector> | 12 #include <vector> |
10 | 13 |
11 #include "base/callback.h" | 14 #include "base/callback.h" |
12 #include "base/macros.h" | |
13 #include "base/memory/scoped_ptr.h" | 15 #include "base/memory/scoped_ptr.h" |
| 16 #include "components/copresence/proto/enums.pb.h" |
14 #include "components/copresence/public/copresence_client_delegate.h" | 17 #include "components/copresence/public/copresence_client_delegate.h" |
| 18 #include "components/copresence/public/whispernet_client.h" |
| 19 #include "components/copresence/rpc/http_post.h" |
| 20 #include "components/copresence/timed_map.h" |
15 | 21 |
16 namespace copresence { | 22 namespace copresence { |
17 | 23 |
| 24 class DirectiveHandler; |
18 class ReportRequest; | 25 class ReportRequest; |
19 class WhispernetClient; | 26 class RequestHeader; |
| 27 class SubscribedMessage; |
20 | 28 |
21 // This class currently handles all communication with the copresence server. | 29 // This class currently handles all communication with the copresence server. |
22 // NOTE: This class is a stub. | |
23 class RpcHandler { | 30 class RpcHandler { |
24 public: | 31 public: |
25 // A callback to indicate whether handler initialization succeeded. | 32 // A callback to indicate whether handler initialization succeeded. |
26 typedef base::Callback<void(bool)> SuccessCallback; | 33 typedef base::Callback<void(bool)> SuccessCallback; |
27 | 34 |
28 // Constructor. May call the server to register a device, | 35 // Report rpc name to send to Apiary. |
29 // so completion status is indicated by the SuccessCallback. | 36 static const char kReportRequestRpcName[]; |
30 RpcHandler(CopresenceClientDelegate* delegate, | 37 |
31 SuccessCallback init_done_callback); | 38 // Constructor. |delegate| is owned by the caller, |
| 39 // and must be valid as long as the RpcHandler exists. |
| 40 explicit RpcHandler(CopresenceClientDelegate* delegate); |
32 | 41 |
33 virtual ~RpcHandler(); | 42 virtual ~RpcHandler(); |
34 | 43 |
| 44 // Clients must call this and wait for |init_done_callback| |
| 45 // to be called before invoking any other methods. |
| 46 void Initialize(const SuccessCallback& init_done_callback); |
| 47 |
35 // Send a report request | 48 // Send a report request |
36 void SendReportRequest(scoped_ptr<copresence::ReportRequest> request); | 49 void SendReportRequest(scoped_ptr<ReportRequest> request); |
37 void SendReportRequest(scoped_ptr<copresence::ReportRequest> request, | 50 void SendReportRequest(scoped_ptr<ReportRequest> request, |
38 const std::string& app_id, | 51 const std::string& app_id, |
39 const StatusCallback& callback); | 52 const StatusCallback& callback); |
40 | 53 |
41 // Report a set of tokens to the server for a given medium. | 54 // Report a set of tokens to the server for a given medium. |
42 void ReportTokens(copresence::TokenMedium medium, | 55 void ReportTokens(TokenMedium medium, const std::vector<std::string>& tokens); |
43 const std::vector<std::string>& tokens); | |
44 | 56 |
45 // Create the directive handler and connect it to the whispernet client. | 57 // Create the directive handler and connect it to |
46 void ConnectToWhispernet(WhispernetClient* whispernet_client); | 58 // the whispernet client specified by the delegate. |
47 | 59 void ConnectToWhispernet(); |
48 // Disconnect the directive handler from the whispernet client. | |
49 void DisconnectFromWhispernet(); | |
50 | 60 |
51 private: | 61 private: |
| 62 // Callback to allow tests to stub out HTTP POST behavior. |
| 63 // Arguments: |
| 64 // URLRequestContextGetter: Context for the HTTP POST request. |
| 65 // string: Name of the rpc to invoke. URL format: server.google.com/rpc_name |
| 66 // MessageLite: Contents of POST request to be sent. This needs to be |
| 67 // a (scoped) pointer to ease handling of the abstract MessageLite class. |
| 68 // ResponseCallback: Receives the response to the request. |
| 69 typedef base::Callback<void(net::URLRequestContextGetter*, |
| 70 const std::string&, |
| 71 scoped_ptr<google::protobuf::MessageLite>, |
| 72 const HttpPost::ResponseCallback&)> PostCallback; |
| 73 |
| 74 friend class RpcHandlerTest; |
| 75 |
| 76 void RegisterResponseHandler(const SuccessCallback& init_done_callback, |
| 77 int http_status_code, |
| 78 const std::string& response_data, |
| 79 HttpPost* completed_post); |
| 80 void ReportResponseHandler(const StatusCallback& status_callback, |
| 81 int http_status_code, |
| 82 const std::string& response_data, |
| 83 HttpPost* completed_post); |
| 84 |
| 85 void DispatchMessages( |
| 86 const google::protobuf::RepeatedPtrField<SubscribedMessage>& |
| 87 subscribed_messages); |
| 88 |
| 89 RequestHeader* CreateRequestHeader(const std::string& client_name) const; |
| 90 |
| 91 template <class T> |
| 92 void SendServerRequest(const std::string& rpc_name, |
| 93 const std::string& app_id, |
| 94 scoped_ptr<T> request, |
| 95 const HttpPost::ResponseCallback& response_handler); |
| 96 |
| 97 // Wrapper for the http post constructor. This is the default way |
| 98 // to contact the server, but it can be overridden for testing. |
| 99 void SendHttpPost(net::URLRequestContextGetter* url_context_getter, |
| 100 const std::string& rpc_name, |
| 101 scoped_ptr<google::protobuf::MessageLite> request_proto, |
| 102 const HttpPost::ResponseCallback& callback); |
| 103 |
| 104 // This method receives the request to encode a token and forwards it to |
| 105 // whispernet, setting the samples return callback to samples_callback. |
| 106 void AudioDirectiveListToWhispernetConnector( |
| 107 const std::string& token, |
| 108 const WhispernetClient::SamplesCallback& samples_callback); |
| 109 |
| 110 CopresenceClientDelegate* delegate_; // Belongs to the caller. |
| 111 TimedMap<std::string, bool> invalid_audio_token_cache_; |
| 112 PostCallback server_post_callback_; |
| 113 |
| 114 std::string device_id_; |
| 115 scoped_ptr<DirectiveHandler> directive_handler_; |
| 116 std::set<HttpPost*> pending_posts_; |
| 117 |
52 DISALLOW_COPY_AND_ASSIGN(RpcHandler); | 118 DISALLOW_COPY_AND_ASSIGN(RpcHandler); |
53 }; | 119 }; |
54 | 120 |
55 } // namespace copresence | 121 } // namespace copresence |
56 | 122 |
57 #endif // COMPONENTS_COPRESENCE_RPC_RPC_HANDLER_H_ | 123 #endif // COMPONENTS_COPRESENCE_RPC_RPC_HANDLER_H_ |
OLD | NEW |