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

Unified Diff: chrome/browser/android/webapk/webapk_update_manager.cc

Issue 2933783002: [Android WebAPK] Change WebAPK update into two phases (Closed)
Patch Set: Merge branch 'master' into background_updates0 Created 3 years, 6 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
« no previous file with comments | « chrome/browser/android/webapk/webapk_update_manager.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
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 177d91580f3fce5425083d90f57b8e154e11d072..6728b2a4ceb7bd48ae705f8ea4f5b7cd4cafdfd8 100644
--- a/chrome/browser/android/webapk/webapk_update_manager.cc
+++ b/chrome/browser/android/webapk/webapk_update_manager.cc
@@ -5,13 +5,20 @@
#include "chrome/browser/android/webapk/webapk_update_manager.h"
#include <jni.h>
+#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 +27,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,
@@ -62,16 +77,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));
ShortcutInfo info(GURL(ConvertJavaStringToUTF8(env, java_start_url)));
info.scope = GURL(ConvertJavaStringToUTF8(env, java_scope));
info.name = ConvertJavaStringToUTF16(env, java_name);
@@ -112,17 +121,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, primary_icon, badge_icon, 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, primary_icon, badge_icon, 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 =
+ base::MakeUnique<std::vector<uint8_t>>();
+ 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));
}
« no previous file with comments | « chrome/browser/android/webapk/webapk_update_manager.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698