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_CRONET_ANDROID_URL_REQUEST_ADAPTER_H_ | 5 #ifndef COMPONENTS_CRONET_ANDROID_CRONET_URL_REQUEST_ADAPTER_H_ |
6 #define COMPONENTS_CRONET_ANDROID_URL_REQUEST_ADAPTER_H_ | 6 #define COMPONENTS_CRONET_ANDROID_CRONET_URL_REQUEST_ADAPTER_H_ |
7 | 7 |
8 #include <jni.h> | 8 #include <jni.h> |
9 | 9 |
10 #include <string> | 10 #include <string> |
11 | 11 |
12 #include "base/macros.h" | 12 #include "base/macros.h" |
13 #include "base/memory/ref_counted.h" | 13 #include "base/memory/ref_counted.h" |
14 #include "base/memory/scoped_ptr.h" | 14 #include "base/memory/scoped_ptr.h" |
15 #include "net/base/request_priority.h" | 15 #include "net/base/request_priority.h" |
16 #include "net/http/http_request_headers.h" | 16 #include "net/http/http_request_headers.h" |
17 #include "net/url_request/url_request.h" | 17 #include "net/url_request/url_request.h" |
18 | 18 |
19 namespace net { | 19 namespace net { |
20 class GrowableIOBuffer; | 20 class GrowableIOBuffer; |
21 class HttpResponseHeaders; | 21 class HttpResponseHeaders; |
22 class UploadDataStream; | 22 class UploadDataStream; |
23 } // namespace net | 23 } // namespace net |
24 | 24 |
25 namespace cronet { | 25 namespace cronet { |
26 | 26 |
27 class URLRequestContextAdapter; | 27 class CronetURLRequestContextAdapter; |
28 | 28 |
29 // An adapter from the JNI |UrlRequest| object and the Chromium |URLRequest| | 29 // An adapter from the JNI |UrlRequest| object and the Chromium |URLRequest| |
30 // object. | 30 // object. |
31 class URLRequestAdapter : public net::URLRequest::Delegate { | 31 class CronetURLRequestAdapter : public net::URLRequest::Delegate { |
32 public: | 32 public: |
33 // The delegate which is called when the request finishes. | 33 // The delegate which is called when the request finishes. |
34 class URLRequestAdapterDelegate | 34 class CronetURLRequestAdapterDelegate |
35 : public base::RefCountedThreadSafe<URLRequestAdapterDelegate> { | 35 : public base::RefCountedThreadSafe<CronetURLRequestAdapterDelegate> { |
36 public: | 36 public: |
37 virtual void OnResponseStarted(URLRequestAdapter* request) = 0; | 37 virtual void OnRedirect(CronetURLRequestAdapter* request, |
38 virtual void OnBytesRead(URLRequestAdapter* request) = 0; | 38 const GURL& newLocation) = 0; |
39 virtual void OnRequestFinished(URLRequestAdapter* request) = 0; | 39 virtual void OnResponseStarted(CronetURLRequestAdapter* request) = 0; |
40 virtual int ReadFromUploadChannel(net::IOBuffer* buf, int buf_length) = 0; | 40 virtual void OnBytesRead(CronetURLRequestAdapter* request, |
41 int bytes_read) = 0; | |
42 virtual void OnRequestFinished(CronetURLRequestAdapter* request, | |
43 bool cancelled) = 0; | |
44 virtual void OnError(CronetURLRequestAdapter* request, int error) = 0; | |
41 | 45 |
42 protected: | 46 protected: |
43 friend class base::RefCountedThreadSafe<URLRequestAdapterDelegate>; | 47 friend class base::RefCountedThreadSafe<CronetURLRequestAdapterDelegate>; |
44 virtual ~URLRequestAdapterDelegate() {} | 48 virtual ~CronetURLRequestAdapterDelegate() {} |
45 }; | 49 }; |
46 | 50 |
47 URLRequestAdapter(URLRequestContextAdapter* context, | 51 CronetURLRequestAdapter(CronetURLRequestContextAdapter* context, |
48 URLRequestAdapterDelegate* delegate, | 52 CronetURLRequestAdapterDelegate* delegate, |
49 GURL url, | 53 GURL url, |
50 net::RequestPriority priority); | 54 net::RequestPriority priority); |
51 virtual ~URLRequestAdapter(); | 55 virtual ~CronetURLRequestAdapter(); |
52 | 56 |
53 // Sets the request method GET, POST etc | 57 // Sets the request method GET, POST etc |
54 void SetMethod(const std::string& method); | 58 void SetMethod(const std::string& method); |
55 | 59 |
56 // Adds a header to the request | 60 // Adds a header to the request |
57 void AddHeader(const std::string& name, const std::string& value); | 61 void AddHeader(const std::string& name, const std::string& value); |
58 | 62 |
59 // Sets the contents of the POST or PUT request | |
60 void SetUploadContent(const char* bytes, int bytes_len); | |
61 | |
62 // Sets the request to streaming upload. | |
63 void SetUploadChannel(JNIEnv* env, int64 content_length); | |
64 | |
65 // Indicates that the request body will be streamed by calling AppendChunk() | |
66 // repeatedly. This must be called before Start(). | |
67 void EnableChunkedUpload(); | |
68 | |
69 // Appends a chunk to the POST body. | |
70 // This must be called after EnableChunkedUpload() and Start(). | |
71 void AppendChunk(const char* bytes, int bytes_len, bool is_last_chunk); | |
72 | |
73 // Starts the request. | 63 // Starts the request. |
74 void Start(); | 64 void Start(); |
75 | 65 |
66 // Follow redirect. | |
67 void FollowDeferredRedirect(); | |
68 | |
69 // Read more data. | |
70 void ReadData(); | |
71 | |
76 // Cancels the request. | 72 // Cancels the request. |
77 void Cancel(); | 73 void Cancel(); |
78 | 74 |
79 // Releases all resources for the request and deletes the object itself. | 75 // Releases all resources for the request and deletes the object itself. |
80 void Destroy(); | 76 void Destroy(); |
81 | 77 |
82 // Returns the URL of the request. | 78 // Returns the URL of the request. |
83 GURL url() const { return url_; } | 79 GURL url() const { return url_; } |
84 | 80 |
85 // Returns the error code after the request is complete. | 81 // Returns the error code after the request is complete. |
86 // Negative codes indicate system errors. | 82 // Negative codes indicate system errors. |
87 int error_code() const { return error_code_; } | 83 int error_code() const { return error_code_; } |
mmenke
2014/10/06 18:28:44
Not used.
mef
2014/10/07 00:45:17
Done.
| |
88 | 84 |
89 // Returns the HTTP status code. | 85 // Returns the HTTP status code. |
90 int http_status_code() const { | 86 int http_status_code() const { return http_status_code_; }; |
91 return http_status_code_; | |
92 }; | |
93 | 87 |
94 // Returns the value of the content-length response header. | 88 // Returns the value of the content-length response header. |
95 int64 content_length() const { return expected_size_; } | 89 int64 content_length() const { return expected_size_; } |
mmenke
2014/10/06 18:28:44
Can tear this out, all the way up through nativeGe
mef
2014/10/07 00:45:17
Done.
| |
96 | 90 |
97 // Returns the value of the content-type response header. | 91 // Returns the value of the content-type response header. |
98 std::string content_type() const { return content_type_; } | 92 std::string content_type() const { return content_type_; } |
mmenke
2014/10/06 18:28:44
Can tear this out, all the way up through nativeGe
mef
2014/10/07 00:45:17
Done.
| |
99 | 93 |
100 // Returns the value of the specified response header. | 94 // Returns the value of the specified response header. |
101 std::string GetHeader(const std::string& name) const; | 95 std::string GetHeader(const std::string& name) const; |
mmenke
2014/10/06 18:28:44
Not used.
mef
2014/10/07 00:45:17
Done.
| |
102 | 96 |
103 // Get all response headers, as a HttpResponseHeaders object. | 97 // Get all response headers, as a HttpResponseHeaders object. |
104 net::HttpResponseHeaders* GetResponseHeaders() const; | 98 net::HttpResponseHeaders* GetResponseHeaders() const; |
105 | 99 |
106 // Returns the overall number of bytes read. | 100 // Returns the overall number of bytes read. |
107 size_t bytes_read() const { return bytes_read_; } | 101 size_t bytes_read() const { return bytes_read_; } |
mmenke
2014/10/06 18:28:44
Not used
mef
2014/10/07 00:45:17
Done.
| |
108 | 102 |
109 // Returns a pointer to the downloaded data. | 103 // Returns a pointer to the downloaded data. |
110 unsigned char* Data() const; | 104 unsigned char* Data() const; |
111 | 105 |
112 // Get NPN or ALPN Negotiated Protocol (if any) from HttpResponseInfo. | 106 // Get NPN or ALPN Negotiated Protocol (if any) from HttpResponseInfo. |
113 std::string GetNegotiatedProtocol() const; | 107 std::string GetNegotiatedProtocol() const; |
114 | 108 |
109 // Returns true if response is coming from the cache. | |
110 bool GetWasCached() const; | |
111 | |
112 // Gets the total amount of data received from network after SSL decoding and | |
113 // proxy handling. | |
114 int64 GetTotalReceivedBytes() const; | |
115 | |
116 // net::URLRequest::Delegate overrides | |
117 virtual void OnReceivedRedirect(net::URLRequest* request, | |
118 const net::RedirectInfo& redirect_info, | |
119 bool* defer_redirect) OVERRIDE; | |
120 | |
115 virtual void OnResponseStarted(net::URLRequest* request) OVERRIDE; | 121 virtual void OnResponseStarted(net::URLRequest* request) OVERRIDE; |
116 | 122 |
117 virtual void OnReadCompleted(net::URLRequest* request, | 123 virtual void OnReadCompleted(net::URLRequest* request, |
118 int bytes_read) OVERRIDE; | 124 int bytes_read) OVERRIDE; |
119 | 125 |
120 private: | 126 private: |
121 static void OnDestroyRequest(URLRequestAdapter* self); | 127 static void DestroyOnNetworkThread(CronetURLRequestAdapter* self); |
128 void StartOnNetworkThread(); | |
129 void FollowDeferredRedirectOnNetworkThread(); | |
130 void ReadDataOnNetworkThread(); | |
131 void CancelOnNetworkThread(); | |
132 // Check status of the request, return true if |is_success()| is true, | |
133 // otherwise report error and cancel request. | |
134 bool CheckStatus(net::URLRequest* request); | |
122 | 135 |
123 void OnInitiateConnection(); | 136 CronetURLRequestContextAdapter* context_; |
124 void OnCancelRequest(); | 137 scoped_refptr<CronetURLRequestAdapterDelegate> delegate_; |
125 void OnRequestSucceeded(); | |
126 void OnRequestFailed(); | |
127 void OnRequestCompleted(); | |
128 void OnRequestCanceled(); | |
129 void OnBytesRead(int bytes_read); | |
130 void OnAppendChunk(const scoped_ptr<char[]> bytes, int bytes_len, | |
131 bool is_last_chunk); | |
132 | |
133 void Read(); | |
134 | |
135 URLRequestContextAdapter* context_; | |
136 scoped_refptr<URLRequestAdapterDelegate> delegate_; | |
137 GURL url_; | 138 GURL url_; |
138 net::RequestPriority priority_; | 139 net::RequestPriority priority_; |
139 std::string method_; | 140 std::string method_; |
140 net::HttpRequestHeaders headers_; | 141 net::HttpRequestHeaders headers_; |
mmenke
2014/10/06 18:28:44
Suggest renaming this, and associated functions, t
mef
2014/10/07 00:45:17
Done.
| |
141 scoped_ptr<net::URLRequest> url_request_; | 142 scoped_ptr<net::URLRequest> url_request_; |
142 scoped_ptr<net::UploadDataStream> upload_data_stream_; | 143 scoped_refptr<net::IOBufferWithSize> read_buffer_; |
143 scoped_refptr<net::GrowableIOBuffer> read_buffer_; | |
144 int bytes_read_; | 144 int bytes_read_; |
145 int total_bytes_read_; | 145 int total_bytes_read_; |
mmenke
2014/10/06 18:28:44
These two are not used.
mef
2014/10/07 00:45:17
Done.
| |
146 int error_code_; | 146 int error_code_; |
mmenke
2014/10/06 18:28:44
Not used.
mef
2014/10/07 00:45:17
Done.
| |
147 int http_status_code_; | 147 int http_status_code_; |
148 std::string content_type_; | 148 std::string content_type_; |
mmenke
2014/10/06 18:28:44
Not used.
mef
2014/10/07 00:45:18
Done.
| |
149 bool canceled_; | 149 bool canceled_; |
150 int64 expected_size_; | 150 int64 expected_size_; |
151 bool chunked_upload_; | 151 bool chunked_upload_; |
152 | 152 |
153 DISALLOW_COPY_AND_ASSIGN(URLRequestAdapter); | 153 DISALLOW_COPY_AND_ASSIGN(CronetURLRequestAdapter); |
154 }; | 154 }; |
155 | 155 |
156 } // namespace cronet | 156 } // namespace cronet |
157 | 157 |
158 #endif // COMPONENTS_CRONET_ANDROID_URL_REQUEST_ADAPTER_H_ | 158 #endif // COMPONENTS_CRONET_ANDROID_CRONET_URL_REQUEST_ADAPTER_H_ |
OLD | NEW |