Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/android/payments/service_worker_payment_app_bridge.h" | |
| 6 | |
| 7 #include "base/android/jni_string.h" | |
| 8 #include "base/android/scoped_java_ref.h" | |
| 9 #include "chrome/browser/profiles/profile_manager.h" | |
| 10 #include "components/payments/payment_app.mojom.h" | |
| 11 #include "content/public/browser/service_worker_context.h" | |
| 12 #include "content/public/browser/storage_partition.h" | |
| 13 #include "jni/ServiceWorkerPaymentAppBridge_jni.h" | |
| 14 | |
| 15 using base::android::ConvertUTF8ToJavaString; | |
| 16 using base::android::JavaParamRef; | |
| 17 using base::android::ScopedJavaLocalRef; | |
| 18 | |
| 19 static ScopedJavaLocalRef<jobject> GetAllAppManifests( | |
| 20 JNIEnv* env, | |
| 21 const JavaParamRef<jclass>& jcaller) { | |
| 22 // TODO(tommyt): crbug.com/669876. Initialise the following two variables. | |
| 23 // At the moment, they are empty, so this function will return an empty | |
| 24 // list of manifests. We need to hook this function up to the service worker | |
| 25 // payment apps. | |
| 26 std::string scope_url; | |
| 27 std::vector<payments::mojom::PaymentAppManifestPtr> manifests; | |
| 28 | |
| 29 ScopedJavaLocalRef<jobject> java_manifests = | |
| 30 Java_ServiceWorkerPaymentAppBridge_createManifestList(env); | |
| 31 for (const auto& manifest : manifests) { | |
| 32 ScopedJavaLocalRef<jobject> java_manifest = | |
| 33 Java_ServiceWorkerPaymentAppBridge_createAndAddManifest( | |
| 34 env, java_manifests, ConvertUTF8ToJavaString(env, scope_url), | |
| 35 ConvertUTF8ToJavaString(env, manifest->label), | |
| 36 ConvertUTF8ToJavaString( | |
| 37 env, manifest->icon ? *manifest->icon : nullptr)); | |
|
Ted C
2016/12/09 18:41:28
looking at the code for jni_string.cc, nullptr loo
tommyt
2016/12/12 10:10:41
No, you're absolutely right.
The ConvertUTF8ToJav
| |
| 38 for (const auto& option : manifest->options) { | |
| 39 ScopedJavaLocalRef<jobject> java_option = | |
| 40 Java_ServiceWorkerPaymentAppBridge_createAndAddOption( | |
| 41 env, java_manifest, ConvertUTF8ToJavaString(env, option->id), | |
| 42 ConvertUTF8ToJavaString(env, option->label), | |
| 43 ConvertUTF8ToJavaString(env, | |
| 44 option->icon ? *option->icon : nullptr)); | |
| 45 for (const auto& enabled_method : option->enabled_methods) { | |
| 46 Java_ServiceWorkerPaymentAppBridge_addEnabledMethod( | |
| 47 env, java_option, ConvertUTF8ToJavaString(env, enabled_method)); | |
| 48 } | |
| 49 } | |
| 50 } | |
| 51 | |
| 52 return java_manifests; | |
| 53 } | |
| 54 | |
| 55 static void InvokePaymentApp(JNIEnv* env, | |
| 56 const JavaParamRef<jclass>& jcaller, | |
| 57 const JavaParamRef<jstring>& scopeUrl, | |
| 58 const JavaParamRef<jstring>& optionId, | |
| 59 const JavaParamRef<jobject>& methodDataMap) { | |
| 60 NOTIMPLEMENTED(); | |
| 61 } | |
| 62 | |
| 63 bool RegisterServiceWorkerPaymentAppBridge(JNIEnv* env) { | |
| 64 return RegisterNativesImpl(env); | |
| 65 } | |
| OLD | NEW |