Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1489)

Unified Diff: android_webview/native/token_binding_manager_bridge.cc

Issue 2863233002: [WebView] Move files from native to browser (Closed)
Patch Set: Created 3 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: android_webview/native/token_binding_manager_bridge.cc
diff --git a/android_webview/native/token_binding_manager_bridge.cc b/android_webview/native/token_binding_manager_bridge.cc
deleted file mode 100644
index 2e71a06a9dcd0e6a2857340e6b04f10eed206ee0..0000000000000000000000000000000000000000
--- a/android_webview/native/token_binding_manager_bridge.cc
+++ /dev/null
@@ -1,119 +0,0 @@
-// Copyright 2016 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 "android_webview/native/token_binding_manager_bridge.h"
-
-#include "android_webview/browser/net/token_binding_manager.h"
-#include "base/android/jni_android.h"
-#include "base/android/jni_array.h"
-#include "base/android/jni_string.h"
-#include "base/bind.h"
-#include "content/public/browser/browser_thread.h"
-#include "crypto/ec_private_key.h"
-#include "jni/AwTokenBindingManager_jni.h"
-#include "net/base/net_errors.h"
-
-using base::android::ConvertJavaStringToUTF8;
-using base::android::JavaParamRef;
-using base::android::ScopedJavaGlobalRef;
-using base::android::ScopedJavaLocalRef;
-using content::BrowserThread;
-
-namespace android_webview {
-
-namespace {
-
-// Provides the key to the Webview client.
-void OnKeyReady(const ScopedJavaGlobalRef<jobject>& callback,
- int status,
- crypto::ECPrivateKey* key) {
- DCHECK_CURRENTLY_ON(BrowserThread::UI);
-
- JNIEnv* env = base::android::AttachCurrentThread();
-
- if (status != net::OK || !key) {
- Java_AwTokenBindingManager_onKeyReady(env, callback, nullptr, nullptr);
- return;
- }
-
- std::vector<uint8_t> private_key;
- key->ExportPrivateKey(&private_key);
- ScopedJavaLocalRef<jbyteArray> jprivate_key = base::android::ToJavaByteArray(
- env, private_key.data(), private_key.size());
-
- std::vector<uint8_t> public_key;
- key->ExportPublicKey(&public_key);
- ScopedJavaLocalRef<jbyteArray> jpublic_key = base::android::ToJavaByteArray(
- env, public_key.data(), public_key.size());
-
- Java_AwTokenBindingManager_onKeyReady(env, callback, jprivate_key,
- jpublic_key);
-}
-
-// Indicates webview client that key deletion is complete.
-void OnDeletionComplete(const ScopedJavaGlobalRef<jobject>& callback) {
- DCHECK_CURRENTLY_ON(BrowserThread::UI);
- if (callback.is_null())
- return;
- JNIEnv* env = base::android::AttachCurrentThread();
- Java_AwTokenBindingManager_onDeletionComplete(env, callback);
-}
-
-} // namespace
-
-static void EnableTokenBinding(JNIEnv* env, const JavaParamRef<jobject>& obj) {
- // This needs to be called before starting chromium engine, so no thread
- // checks for UI.
- TokenBindingManager::GetInstance()->enable_token_binding();
-}
-
-static void GetTokenBindingKey(JNIEnv* env,
- const JavaParamRef<jobject>& obj,
- const JavaParamRef<jstring>& host,
- const JavaParamRef<jobject>& callback) {
- DCHECK_CURRENTLY_ON(BrowserThread::UI);
- // Store the Java callback in a scoped object and give the ownership to
- // base::Callback
- ScopedJavaGlobalRef<jobject> j_callback;
- j_callback.Reset(env, callback);
-
- TokenBindingManager::KeyReadyCallback key_callback =
- base::Bind(&OnKeyReady, j_callback);
- TokenBindingManager::GetInstance()->GetKey(ConvertJavaStringToUTF8(env, host),
- key_callback);
-}
-
-static void DeleteTokenBindingKey(JNIEnv* env,
- const JavaParamRef<jobject>& obj,
- const JavaParamRef<jstring>& host,
- const JavaParamRef<jobject>& callback) {
- DCHECK_CURRENTLY_ON(BrowserThread::UI);
- // Store the Java callback in a scoped object and give the ownership to
- // base::Callback
- ScopedJavaGlobalRef<jobject> j_callback;
- j_callback.Reset(env, callback);
- TokenBindingManager::DeletionCompleteCallback complete_callback =
- base::Bind(&OnDeletionComplete, j_callback);
- TokenBindingManager::GetInstance()->DeleteKey(
- ConvertJavaStringToUTF8(env, host), complete_callback);
-}
-
-static void DeleteAllTokenBindingKeys(JNIEnv* env,
- const JavaParamRef<jobject>& obj,
- const JavaParamRef<jobject>& callback) {
- DCHECK_CURRENTLY_ON(BrowserThread::UI);
- // Store the Java callback in a scoped object and give the ownership to
- // base::Callback
- ScopedJavaGlobalRef<jobject> j_callback;
- j_callback.Reset(env, callback);
- TokenBindingManager::DeletionCompleteCallback complete_callback =
- base::Bind(&OnDeletionComplete, j_callback);
- TokenBindingManager::GetInstance()->DeleteAllKeys(complete_callback);
-}
-
-bool RegisterTokenBindingManager(JNIEnv* env) {
- return RegisterNativesImpl(env);
-}
-
-} // android_webview namespace

Powered by Google App Engine
This is Rietveld 408576698