| Index: components/cronet/android/cronet_url_request.cc
|
| diff --git a/components/cronet/android/chromium_url_request.cc b/components/cronet/android/cronet_url_request.cc
|
| similarity index 57%
|
| copy from components/cronet/android/chromium_url_request.cc
|
| copy to components/cronet/android/cronet_url_request.cc
|
| index b2291b38799b4dd4759b412e1f93a494514c9c07..09597863e66f99cafb31987b465f8ecffefd27ce 100644
|
| --- a/components/cronet/android/chromium_url_request.cc
|
| +++ b/components/cronet/android/cronet_url_request.cc
|
| @@ -2,14 +2,14 @@
|
| // Use of this source code is governed by a BSD-style license that can be
|
| // found in the LICENSE file.
|
|
|
| -#include "components/cronet/android/chromium_url_request.h"
|
| +#include "components/cronet/android/cronet_url_request.h"
|
|
|
| #include "base/android/jni_android.h"
|
| #include "base/android/jni_string.h"
|
| #include "base/macros.h"
|
| -#include "components/cronet/android/url_request_adapter.h"
|
| -#include "components/cronet/android/url_request_context_adapter.h"
|
| -#include "jni/ChromiumUrlRequest_jni.h"
|
| +#include "components/cronet/android/cronet_url_request_adapter.h"
|
| +#include "components/cronet/android/cronet_url_request_context_adapter.h"
|
| +#include "jni/CronetUrlRequest_jni.h"
|
| #include "net/base/net_errors.h"
|
| #include "net/base/request_priority.h"
|
| #include "net/http/http_response_headers.h"
|
| @@ -35,63 +35,49 @@ net::RequestPriority ConvertRequestPriority(jint request_priority) {
|
| return net::LOWEST;
|
| }
|
| }
|
| -
|
| -void SetPostContentType(JNIEnv* env,
|
| - URLRequestAdapter* request,
|
| - jstring content_type) {
|
| - DCHECK(request != NULL);
|
| -
|
| - std::string method_post("POST");
|
| - request->SetMethod(method_post);
|
| -
|
| - std::string content_type_header("Content-Type");
|
| - std::string content_type_string(
|
| - base::android::ConvertJavaStringToUTF8(env, content_type));
|
| -
|
| - request->AddHeader(content_type_header, content_type_string);
|
| -}
|
| -
|
| -// A delegate of URLRequestAdapter that delivers callbacks to the Java layer.
|
| -class JniURLRequestAdapterDelegate
|
| - : public URLRequestAdapter::URLRequestAdapterDelegate {
|
| +// A delegate of CronetURLRequestAdapter that delivers callbacks to the Java
|
| +// layer.
|
| +class JniCronetURLRequestAdapterDelegate
|
| + : public CronetURLRequestAdapter::CronetURLRequestAdapterDelegate {
|
| public:
|
| - JniURLRequestAdapterDelegate(JNIEnv* env, jobject owner) {
|
| + JniCronetURLRequestAdapterDelegate(JNIEnv* env, jobject owner) {
|
| owner_ = env->NewGlobalRef(owner);
|
| }
|
|
|
| - virtual void OnResponseStarted(URLRequestAdapter* request) OVERRIDE {
|
| + virtual void OnRedirect(CronetURLRequestAdapter* request,
|
| + const GURL& newLocation) OVERRIDE {
|
| JNIEnv* env = base::android::AttachCurrentThread();
|
| - cronet::Java_ChromiumUrlRequest_onResponseStarted(env, owner_);
|
| + cronet::Java_CronetUrlRequest_onRedirect(
|
| + env,
|
| + owner_,
|
| + ConvertUTF8ToJavaString(env, newLocation.spec()).Release());
|
| }
|
|
|
| - virtual void OnBytesRead(URLRequestAdapter* request) OVERRIDE {
|
| - int bytes_read = request->bytes_read();
|
| - if (bytes_read != 0) {
|
| - JNIEnv* env = base::android::AttachCurrentThread();
|
| + virtual void OnResponseStarted(CronetURLRequestAdapter* request) OVERRIDE {
|
| + JNIEnv* env = base::android::AttachCurrentThread();
|
| + cronet::Java_CronetUrlRequest_onResponseStarted(env, owner_);
|
| + }
|
| +
|
| + virtual void OnBytesRead(CronetURLRequestAdapter* request,
|
| + int bytes_read) OVERRIDE {
|
| + JNIEnv* env = base::android::AttachCurrentThread();
|
| + if (bytes_read >= 0) {
|
| base::android::ScopedJavaLocalRef<jobject> java_buffer(
|
| env, env->NewDirectByteBuffer(request->Data(), bytes_read));
|
| - cronet::Java_ChromiumUrlRequest_onBytesRead(
|
| + cronet::Java_CronetUrlRequest_onDataReceived(
|
| env, owner_, java_buffer.obj());
|
| + } else {
|
| + cronet::Java_CronetUrlRequest_onError(env, owner_, request->error_code());
|
| }
|
| }
|
|
|
| - virtual void OnRequestFinished(URLRequestAdapter* request) OVERRIDE {
|
| + virtual void OnRequestFinished(CronetURLRequestAdapter* request) OVERRIDE {
|
| JNIEnv* env = base::android::AttachCurrentThread();
|
| - cronet::Java_ChromiumUrlRequest_finish(env, owner_);
|
| - }
|
| -
|
| - virtual int ReadFromUploadChannel(net::IOBuffer* buf,
|
| - int buf_length) OVERRIDE {
|
| - JNIEnv* env = base::android::AttachCurrentThread();
|
| - base::android::ScopedJavaLocalRef<jobject> java_buffer(
|
| - env, env->NewDirectByteBuffer(buf->data(), buf_length));
|
| - jint bytes_read = cronet::Java_ChromiumUrlRequest_readFromUploadChannel(
|
| - env, owner_, java_buffer.obj());
|
| - return bytes_read;
|
| + cronet::Java_CronetUrlRequest_onComplete(env, owner_);
|
| }
|
|
|
| protected:
|
| - virtual ~JniURLRequestAdapterDelegate() {
|
| + virtual ~JniCronetURLRequestAdapterDelegate() {
|
| JNIEnv* env = base::android::AttachCurrentThread();
|
| env->DeleteGlobalRef(owner_);
|
| }
|
| @@ -99,13 +85,13 @@ class JniURLRequestAdapterDelegate
|
| private:
|
| jobject owner_;
|
|
|
| - DISALLOW_COPY_AND_ASSIGN(JniURLRequestAdapterDelegate);
|
| + DISALLOW_COPY_AND_ASSIGN(JniCronetURLRequestAdapterDelegate);
|
| };
|
|
|
| } // namespace
|
|
|
| // Explicitly register static JNI functions.
|
| -bool ChromiumUrlRequestRegisterJni(JNIEnv* env) {
|
| +bool CronetUrlRequestRegisterJni(JNIEnv* env) {
|
| return RegisterNativesImpl(env);
|
| }
|
|
|
| @@ -114,19 +100,20 @@ static jlong CreateRequestAdapter(JNIEnv* env,
|
| jlong urlRequestContextAdapter,
|
| jstring url_string,
|
| jint priority) {
|
| - URLRequestContextAdapter* context =
|
| - reinterpret_cast<URLRequestContextAdapter*>(urlRequestContextAdapter);
|
| + CronetURLRequestContextAdapter* context =
|
| + reinterpret_cast<CronetURLRequestContextAdapter*>(
|
| + urlRequestContextAdapter);
|
| DCHECK(context != NULL);
|
|
|
| GURL url(base::android::ConvertJavaStringToUTF8(env, url_string));
|
|
|
| VLOG(1) << "New chromium network request: " << url.possibly_invalid_spec();
|
|
|
| - URLRequestAdapter* adapter =
|
| - new URLRequestAdapter(context,
|
| - new JniURLRequestAdapterDelegate(env, object),
|
| - url,
|
| - ConvertRequestPriority(priority));
|
| + CronetURLRequestAdapter* adapter = new CronetURLRequestAdapter(
|
| + context,
|
| + new JniCronetURLRequestAdapterDelegate(env, object),
|
| + url,
|
| + ConvertRequestPriority(priority));
|
|
|
| return reinterpret_cast<jlong>(adapter);
|
| }
|
| @@ -137,8 +124,8 @@ static void AddHeader(JNIEnv* env,
|
| jlong urlRequestAdapter,
|
| jstring name,
|
| jstring value) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| DCHECK(request);
|
|
|
| std::string name_string(base::android::ConvertJavaStringToUTF8(env, name));
|
| @@ -147,12 +134,12 @@ static void AddHeader(JNIEnv* env,
|
| request->AddHeader(name_string, value_string);
|
| }
|
|
|
| -static void SetMethod(JNIEnv* env,
|
| - jobject object,
|
| - jlong urlRequestAdapter,
|
| - jstring method) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| +static void SetHttpMethod(JNIEnv* env,
|
| + jobject object,
|
| + jlong urlRequestAdapter,
|
| + jstring method) {
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| DCHECK(request);
|
|
|
| std::string method_string(
|
| @@ -161,68 +148,10 @@ static void SetMethod(JNIEnv* env,
|
| request->SetMethod(method_string);
|
| }
|
|
|
| -static void SetUploadData(JNIEnv* env,
|
| - jobject object,
|
| - jlong urlRequestAdapter,
|
| - jstring content_type,
|
| - jbyteArray content) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| - SetPostContentType(env, request, content_type);
|
| -
|
| - if (content != NULL) {
|
| - jsize size = env->GetArrayLength(content);
|
| - if (size > 0) {
|
| - jbyte* content_bytes = env->GetByteArrayElements(content, NULL);
|
| - request->SetUploadContent(reinterpret_cast<const char*>(content_bytes),
|
| - size);
|
| - env->ReleaseByteArrayElements(content, content_bytes, 0);
|
| - }
|
| - }
|
| -}
|
| -
|
| -static void SetUploadChannel(JNIEnv* env,
|
| - jobject object,
|
| - jlong urlRequestAdapter,
|
| - jstring content_type,
|
| - jlong content_length) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| - SetPostContentType(env, request, content_type);
|
| -
|
| - request->SetUploadChannel(env, content_length);
|
| -}
|
| -
|
| -static void EnableChunkedUpload(JNIEnv* env,
|
| - jobject object,
|
| - jlong urlRequestAdapter,
|
| - jstring content_type) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| - SetPostContentType(env, request, content_type);
|
| -
|
| - request->EnableChunkedUpload();
|
| -}
|
| -
|
| -static void AppendChunk(JNIEnv* env,
|
| - jobject object,
|
| - jlong urlRequestAdapter,
|
| - jobject chunk_byte_buffer,
|
| - jint chunk_size,
|
| - jboolean is_last_chunk) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| - DCHECK(chunk_byte_buffer != NULL);
|
| -
|
| - void* chunk = env->GetDirectBufferAddress(chunk_byte_buffer);
|
| - request->AppendChunk(
|
| - reinterpret_cast<const char*>(chunk), chunk_size, is_last_chunk);
|
| -}
|
| -
|
| /* synchronized */
|
| static void Start(JNIEnv* env, jobject object, jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request != NULL) {
|
| request->Start();
|
| }
|
| @@ -232,8 +161,8 @@ static void Start(JNIEnv* env, jobject object, jlong urlRequestAdapter) {
|
| static void DestroyRequestAdapter(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request != NULL) {
|
| request->Destroy();
|
| }
|
| @@ -241,16 +170,34 @@ static void DestroyRequestAdapter(JNIEnv* env,
|
|
|
| /* synchronized */
|
| static void Cancel(JNIEnv* env, jobject object, jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request != NULL) {
|
| request->Cancel();
|
| }
|
| }
|
|
|
| +static void ReceiveData(JNIEnv* env, jobject jcaller, jlong urlRequestAdapter) {
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| + if (request != NULL) {
|
| + request->ReadData();
|
| + }
|
| +}
|
| +
|
| +static void FollowDeferredRedirect(JNIEnv* env,
|
| + jobject jcaller,
|
| + jlong urlRequestAdapter) {
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| + if (request != NULL) {
|
| + request->FollowDeferredRedirect();
|
| + }
|
| +}
|
| +
|
| static jint GetErrorCode(JNIEnv* env, jobject object, jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| int error_code = request->error_code();
|
| switch (error_code) {
|
| // TODO(mef): Investigate returning success on positive values, too, as
|
| @@ -287,8 +234,8 @@ static jint GetErrorCode(JNIEnv* env, jobject object, jlong urlRequestAdapter) {
|
| static jstring GetErrorString(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| int error_code = request->error_code();
|
| char buffer[200];
|
| std::string error_string = net::ErrorToString(error_code);
|
| @@ -303,16 +250,16 @@ static jstring GetErrorString(JNIEnv* env,
|
| static jint GetHttpStatusCode(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| return request->http_status_code();
|
| }
|
|
|
| static jstring GetContentType(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request == NULL) {
|
| return NULL;
|
| }
|
| @@ -327,8 +274,8 @@ static jstring GetContentType(JNIEnv* env,
|
| static jlong GetContentLength(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request == NULL) {
|
| return 0;
|
| }
|
| @@ -339,8 +286,8 @@ static jstring GetHeader(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter,
|
| jstring name) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request == NULL) {
|
| return NULL;
|
| }
|
| @@ -358,8 +305,8 @@ static void GetAllHeaders(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter,
|
| jobject headersMap) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request == NULL)
|
| return;
|
|
|
| @@ -375,7 +322,7 @@ static void GetAllHeaders(JNIEnv* env,
|
| ConvertUTF8ToJavaString(env, header_name);
|
| ScopedJavaLocalRef<jstring> value =
|
| ConvertUTF8ToJavaString(env, header_value);
|
| - Java_ChromiumUrlRequest_onAppendResponseHeader(
|
| + Java_CronetUrlRequest_onAppendResponseHeader(
|
| env, object, headersMap, name.Release(), value.Release());
|
| }
|
|
|
| @@ -383,15 +330,15 @@ static void GetAllHeaders(JNIEnv* env,
|
| // null key; in HTTP's case, this maps to the HTTP status line.
|
| ScopedJavaLocalRef<jstring> status_line =
|
| ConvertUTF8ToJavaString(env, headers->GetStatusLine());
|
| - Java_ChromiumUrlRequest_onAppendResponseHeader(
|
| + Java_CronetUrlRequest_onAppendResponseHeader(
|
| env, object, headersMap, NULL, status_line.Release());
|
| }
|
|
|
| static jstring GetNegotiatedProtocol(JNIEnv* env,
|
| jobject object,
|
| jlong urlRequestAdapter) {
|
| - URLRequestAdapter* request =
|
| - reinterpret_cast<URLRequestAdapter*>(urlRequestAdapter);
|
| + CronetURLRequestAdapter* request =
|
| + reinterpret_cast<CronetURLRequestAdapter*>(urlRequestAdapter);
|
| if (request == NULL)
|
| return ConvertUTF8ToJavaString(env, "").Release();
|
|
|
|
|