Chromium Code Reviews| Index: chrome/browser/android/webapk/webapk_update_manager.cc |
| diff --git a/chrome/browser/android/webapk/webapk_update_manager.cc b/chrome/browser/android/webapk/webapk_update_manager.cc |
| index 8c3bcce44941afbba5ca0dd23419769f24302f11..1a78c31a6c8900fff6c1076a79a8646ed4f85d11 100644 |
| --- a/chrome/browser/android/webapk/webapk_update_manager.cc |
| +++ b/chrome/browser/android/webapk/webapk_update_manager.cc |
| @@ -6,12 +6,17 @@ |
| #include <jni.h> |
|
dominickn
2017/06/14 00:14:23
#include <memory>
#include <vector>
|
| +#include "base/android/callback_android.h" |
| #include "base/android/jni_array.h" |
| #include "base/android/jni_string.h" |
| +#include "base/android/scoped_java_ref.h" |
| #include "base/bind.h" |
| +#include "base/memory/ptr_util.h" |
| +#include "base/strings/string16.h" |
| #include "base/threading/thread_task_runner_handle.h" |
| #include "chrome/browser/android/shortcut_info.h" |
| #include "chrome/browser/android/webapk/webapk_install_service.h" |
| +#include "chrome/browser/android/webapk/webapk_installer.h" |
| #include "chrome/browser/profiles/profile.h" |
| #include "chrome/browser/profiles/profile_manager.h" |
| #include "content/public/browser/browser_thread.h" |
| @@ -20,31 +25,39 @@ |
| #include "ui/gfx/android/java_bitmap.h" |
| #include "url/gurl.h" |
| +using base::android::JavaRef; |
| using base::android::JavaParamRef; |
| +using base::android::ScopedJavaGlobalRef; |
| -// static |
| -bool WebApkUpdateManager::Register(JNIEnv* env) { |
| - return RegisterNativesImpl(env); |
| +namespace { |
| + |
| +// Called with the serialized proto to send to the WebAPK server. |
| +void OnBuiltProto(const JavaRef<jobject>& java_callback, |
| + std::unique_ptr<std::vector<uint8_t>> proto) { |
| + base::android::RunCallbackAndroid(java_callback, *proto); |
| } |
| -// static |
| -void WebApkUpdateManager::OnBuiltWebApk(const std::string& id, |
| - WebApkInstallResult result, |
| - bool relax_updates, |
| - const std::string& webapk_package) { |
| +// Called after the update either succeeds or fails. |
| +void OnUpdated(const JavaRef<jobject>& java_callback, |
| + WebApkInstallResult result, |
| + bool relax_updates, |
| + const std::string& webapk_package) { |
| JNIEnv* env = base::android::AttachCurrentThread(); |
| + Java_WebApkUpdateCallback_onResultFromNative( |
| + env, java_callback, static_cast<int>(result), relax_updates); |
| +} |
| - base::android::ScopedJavaLocalRef<jstring> java_id = |
| - base::android::ConvertUTF8ToJavaString(env, id); |
| - Java_WebApkUpdateManager_onBuiltWebApk( |
| - env, java_id.obj(), static_cast<int>(result), relax_updates); |
| +} // anonymous namespace |
| + |
| +// static |
| +bool WebApkUpdateManager::Register(JNIEnv* env) { |
| + return RegisterNativesImpl(env); |
| } |
| // static JNI method. |
| -static void UpdateAsync( |
| +static void BuildUpdateWebApkProto( |
| JNIEnv* env, |
| const JavaParamRef<jclass>& clazz, |
| - const JavaParamRef<jstring>& java_id, |
| const JavaParamRef<jstring>& java_start_url, |
| const JavaParamRef<jstring>& java_scope, |
| const JavaParamRef<jstring>& java_name, |
| @@ -60,16 +73,10 @@ static void UpdateAsync( |
| const JavaParamRef<jstring>& java_web_manifest_url, |
| const JavaParamRef<jstring>& java_webapk_package, |
| jint java_webapk_version, |
| - jboolean java_is_manifest_stale) { |
| + jboolean java_is_manifest_stale, |
| + const JavaParamRef<jobject>& java_callback) { |
| DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| - Profile* profile = ProfileManager::GetLastUsedProfile(); |
| - if (profile == nullptr) { |
| - NOTREACHED() << "Profile not found."; |
| - return; |
| - } |
| - |
| - std::string id(ConvertJavaStringToUTF8(env, java_id)); |
| GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); |
| GURL scope(ConvertJavaStringToUTF8(env, java_scope)); |
| GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url)); |
| @@ -107,17 +114,43 @@ static void UpdateAsync( |
| std::string webapk_package; |
| ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); |
| - WebApkInstallService* install_service = WebApkInstallService::Get(profile); |
| - if (install_service->IsInstallInProgress(info.manifest_url)) { |
| + WebApkInstaller::BuildProto( |
| + info, best_primary_icon_bitmap, SkBitmap(), webapk_package, |
| + std::to_string(java_webapk_version), icon_url_to_murmur2_hash, |
| + java_is_manifest_stale, |
| + base::Bind(&OnBuiltProto, ScopedJavaGlobalRef<jobject>(java_callback))); |
| +} |
| + |
| +// static JNI method. |
| +static void UpdateWebApk(JNIEnv* env, |
| + const JavaParamRef<jclass>& clazz, |
| + const JavaParamRef<jstring>& java_webapk_package, |
| + const JavaParamRef<jstring>& java_start_url, |
| + const JavaParamRef<jstring>& java_short_name, |
| + const JavaParamRef<jbyteArray>& java_serialized_proto, |
| + const JavaParamRef<jobject>& java_callback) { |
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| + |
| + ScopedJavaGlobalRef<jobject> callback_ref(java_callback); |
| + |
| + Profile* profile = ProfileManager::GetLastUsedProfile(); |
| + if (profile == nullptr) { |
| base::ThreadTaskRunnerHandle::Get()->PostTask( |
| FROM_HERE, |
| - base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id, |
| - WebApkInstallResult::FAILURE, false /* relax_updates */, |
| - "" /* webapk_package */)); |
| + base::Bind(&OnUpdated, callback_ref, WebApkInstallResult::FAILURE, |
| + false /* relax_updates */, "" /* webapk_package */)); |
| return; |
| } |
| - install_service->UpdateAsync( |
| - info, best_primary_icon_bitmap, webapk_package, java_webapk_version, |
| - icon_url_to_murmur2_hash, java_is_manifest_stale, |
| - base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id)); |
| + |
| + std::string webapk_package = |
| + ConvertJavaStringToUTF8(env, java_webapk_package); |
| + GURL start_url = GURL(ConvertJavaStringToUTF8(env, java_start_url)); |
| + base::string16 short_name = ConvertJavaStringToUTF16(env, java_short_name); |
| + std::unique_ptr<std::vector<uint8_t>> serialized_proto( |
| + new std::vector<uint8_t>); |
|
dominickn
2017/06/14 00:14:23
base::MakeUnique
|
| + JavaByteArrayToByteVector(env, java_serialized_proto, serialized_proto.get()); |
| + |
| + WebApkInstallService::Get(profile)->UpdateAsync( |
| + webapk_package, start_url, short_name, std::move(serialized_proto), |
| + base::Bind(&OnUpdated, callback_ref)); |
| } |