Index: components/copresence/rpc/http_post.h |
diff --git a/components/copresence/rpc/http_post.h b/components/copresence/rpc/http_post.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..33df7a69b84c826f4b7eee4e6b1e52bbbd587687 |
--- /dev/null |
+++ b/components/copresence/rpc/http_post.h |
@@ -0,0 +1,69 @@ |
+// Copyright 2014 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef COMPONENTS_COPRESENCE_RPC_HTTP_POST_H_ |
+#define COMPONENTS_COPRESENCE_RPC_HTTP_POST_H_ |
+ |
+#include <string> |
+ |
+#include "base/callback.h" |
+#include "base/macros.h" |
+#include "base/memory/scoped_ptr.h" |
+#include "base/memory/weak_ptr.h" |
+#include "net/url_request/url_fetcher_delegate.h" |
+ |
+namespace google { |
+namespace protobuf { |
+class MessageLite; |
+} |
+} |
+ |
+namespace net { |
+class URLRequestContextGetter; |
+} |
+ |
+namespace copresence { |
+ |
+// This class handles all Apiary calls to the Copresence server. |
+// It configures the HTTP request appropriately and reports any errors. |
+// Clients should not attempt to delete this class, as it needs to |
+// persist until the HTTP request completes (or times out). |
+// |
+// TODO(ckehoe): Add retry logic. |
+class HttpPost : public net::URLFetcherDelegate, |
+ public base::SupportsWeakPtr<HttpPost> { |
+ public: |
+ // Callback to receive the HTTP status code and body of the response (if any). |
+ typedef base::Callback<void(int, const std::string&)> ResponseCallback; |
+ |
+ // An id for testing url fetching. |
+ static const int kUrlFetcherId = 1; |
+ |
+ // Send a request to the Copresence server. After calling the callback, this |
+ // object will delete itself. |url_context_getter| is owned by the caller, |
+ // and must be valid until the request is actually sent (on the IO thread). |
+ HttpPost(net::URLRequestContextGetter* url_context_getter, |
+ const std::string& server_host, |
+ const std::string& rpc_name, |
+ const google::protobuf::MessageLite& request_proto, |
+ const ResponseCallback& response_callback); |
+ |
+ private: |
+ // This class deletes itself when the request completes (or times out). |
+ // TODO(ckehoe): Self-deletion is a possible source of memory leaks. |
willchan no longer on Chromium
2014/08/06 23:57:39
During profile shutdown, all the network objects t
Charlie
2014/08/07 00:08:24
Ok. Before I write the code, can you confirm if th
willchan no longer on Chromium
2014/08/07 00:11:40
Sorry, I just got started with the review. But I s
rkc
2014/08/07 00:18:20
I would assume this is what you'd do?
1.) Keep a v
|
+ // Re-think the lifecycle management here. |
+ virtual ~HttpPost(); |
+ |
+ // Overridden from net::URLFetcherDelegate. |
+ virtual void OnURLFetchComplete(const net::URLFetcher* source) OVERRIDE; |
+ |
+ ResponseCallback response_callback_; |
+ scoped_ptr<net::URLFetcher> url_fetcher_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(HttpPost); |
+}; |
+ |
+} // namespace copresence |
+ |
+#endif // COMPONENTS_COPRESENCE_RPC_HTTP_POST_H_ |