| Index: components/cronet/android/cronet_url_request_context.cc
|
| diff --git a/components/cronet/android/cronet_url_request_context.cc b/components/cronet/android/cronet_url_request_context.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..52091f8f94847431f87af8d5d64baf836ccdd5c1
|
| --- /dev/null
|
| +++ b/components/cronet/android/cronet_url_request_context.cc
|
| @@ -0,0 +1,134 @@
|
| +// 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.
|
| +
|
| +#include "components/cronet/android/cronet_url_request_context.h"
|
| +
|
| +#include <string>
|
| +
|
| +#include "base/android/jni_android.h"
|
| +#include "base/android/jni_string.h"
|
| +#include "base/json/json_reader.h"
|
| +#include "base/logging.h"
|
| +#include "base/memory/scoped_ptr.h"
|
| +#include "base/metrics/statistics_recorder.h"
|
| +#include "base/values.h"
|
| +#include "components/cronet/android/cronet_url_request.h"
|
| +#include "components/cronet/android/cronet_url_request_adapter.h"
|
| +#include "components/cronet/android/cronet_url_request_context_adapter.h"
|
| +#include "components/cronet/url_request_context_config.h"
|
| +#include "jni/CronetUrlRequestContext_jni.h"
|
| +
|
| +namespace {
|
| +
|
| +void initJavaNetworkThread(jobject jowner) {
|
| + JNIEnv* jenv = base::android::AttachCurrentThread();
|
| + cronet::Java_CronetUrlRequestContext_initNetworkThread(jenv, jowner);
|
| + jenv->DeleteGlobalRef(jowner);
|
| +}
|
| +
|
| +} // namespace
|
| +
|
| +namespace cronet {
|
| +
|
| +// Explicitly register static JNI functions.
|
| +bool CronetUrlRequestContextRegisterJni(JNIEnv* jenv) {
|
| + return RegisterNativesImpl(jenv);
|
| +}
|
| +
|
| +// Sets global user-agent to be used for all subsequent requests.
|
| +static jlong CreateRequestContextAdapter(JNIEnv* jenv,
|
| + jobject jcaller,
|
| + jobject japp_context,
|
| + jint jlog_level,
|
| + jstring jconfig) {
|
| + std::string config_string =
|
| + base::android::ConvertJavaStringToUTF8(jenv, jconfig);
|
| +
|
| + scoped_ptr<base::Value> config_value(base::JSONReader::Read(config_string));
|
| + if (!config_value || !config_value->IsType(base::Value::TYPE_DICTIONARY)) {
|
| + DLOG(ERROR) << "Bad JSON: " << config_string;
|
| + return 0;
|
| + }
|
| +
|
| + scoped_ptr<URLRequestContextConfig> context_config(
|
| + new URLRequestContextConfig());
|
| + base::JSONValueConverter<URLRequestContextConfig> converter;
|
| + if (!converter.Convert(*config_value, context_config.get())) {
|
| + DLOG(ERROR) << "Bad Config: " << config_value;
|
| + return 0;
|
| + }
|
| +
|
| + // Set application context.
|
| + base::android::ScopedJavaLocalRef<jobject> scoped_context(jenv, japp_context);
|
| + base::android::InitApplicationContext(jenv, scoped_context);
|
| +
|
| + // TODO(mef): MinLogLevel is global, shared by all URLRequestContexts.
|
| + // Revisit this if each URLRequestContext would need an individual log level.
|
| + logging::SetMinLogLevel(static_cast<int>(jlog_level));
|
| +
|
| + CronetURLRequestContextAdapter* context_adapter =
|
| + new CronetURLRequestContextAdapter();
|
| + base::Closure init_java_network_thread = base::Bind (
|
| + &initJavaNetworkThread,
|
| + jenv->NewGlobalRef(jcaller));
|
| + context_adapter->Initialize(context_config.Pass(), init_java_network_thread);
|
| +
|
| + return reinterpret_cast<jlong>(context_adapter);
|
| +}
|
| +
|
| +// Destroys native objects.
|
| +static void DestroyRequestContextAdapter(JNIEnv* jenv,
|
| + jobject jcaller,
|
| + jlong jurl_request_context_adapter) {
|
| + if (jurl_request_context_adapter == 0)
|
| + return;
|
| + CronetURLRequestContextAdapter* context_adapter =
|
| + reinterpret_cast<CronetURLRequestContextAdapter*>(
|
| + jurl_request_context_adapter);
|
| + context_adapter->Destroy();
|
| +}
|
| +
|
| +// Starts recording statistics.
|
| +static void InitializeStatistics(JNIEnv* jenv, jobject jcaller) {
|
| + base::StatisticsRecorder::Initialize();
|
| +}
|
| +
|
| +// Gets current statistics with |filter| as a substring as JSON text (an empty
|
| +// |filter| will include all registered histograms).
|
| +static jstring GetStatisticsJSON(JNIEnv* jenv,
|
| + jobject jcaller,
|
| + jstring jfilter) {
|
| + std::string query = base::android::ConvertJavaStringToUTF8(jenv, jfilter);
|
| + std::string json = base::StatisticsRecorder::ToJSON(query);
|
| + return base::android::ConvertUTF8ToJavaString(jenv, json).Release();
|
| +}
|
| +
|
| +// Starts recording NetLog into file with |fileName|.
|
| +static void StartNetLogToFile(JNIEnv* jenv,
|
| + jobject jcaller,
|
| + jlong jurl_request_context_adapter,
|
| + jstring fileName) {
|
| + if (jurl_request_context_adapter == 0)
|
| + return;
|
| + CronetURLRequestContextAdapter* context_adapter =
|
| + reinterpret_cast<CronetURLRequestContextAdapter*>(
|
| + jurl_request_context_adapter);
|
| + std::string file_name =
|
| + base::android::ConvertJavaStringToUTF8(jenv, fileName);
|
| + context_adapter->StartNetLogToFile(file_name);
|
| +}
|
| +
|
| +// Stops recording NetLog.
|
| +static void StopNetLog(JNIEnv* jenv,
|
| + jobject jcaller,
|
| + jlong jurl_request_context_adapter) {
|
| + if (jurl_request_context_adapter == 0)
|
| + return;
|
| + CronetURLRequestContextAdapter* context_adapter =
|
| + reinterpret_cast<CronetURLRequestContextAdapter*>(
|
| + jurl_request_context_adapter);
|
| + context_adapter->StopNetLog();
|
| +}
|
| +
|
| +} // namespace cronet
|
|
|