| OLD | NEW |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/android/webapk/webapk_update_manager.h" | 5 #include "chrome/browser/android/webapk/webapk_update_manager.h" |
| 6 | 6 |
| 7 #include <jni.h> | 7 #include <jni.h> |
| 8 | 8 |
| 9 #include "base/android/jni_string.h" | 9 #include "base/android/jni_string.h" |
| 10 #include "base/bind.h" | 10 #include "base/bind.h" |
| 11 #include "chrome/browser/android/webapk/webapk_installer.h" | 11 #include "chrome/browser/android/webapk/webapk_installer.h" |
| 12 #include "chrome/browser/profiles/profile.h" | 12 #include "chrome/browser/profiles/profile.h" |
| 13 #include "chrome/browser/profiles/profile_manager.h" | 13 #include "chrome/browser/profiles/profile_manager.h" |
| 14 #include "content/public/browser/browser_thread.h" | 14 #include "content/public/browser/browser_thread.h" |
| 15 #include "jni/WebApkUpdateManager_jni.h" | 15 #include "jni/WebApkUpdateManager_jni.h" |
| 16 #include "third_party/skia/include/core/SkBitmap.h" | 16 #include "third_party/skia/include/core/SkBitmap.h" |
| 17 #include "ui/gfx/android/java_bitmap.h" | 17 #include "ui/gfx/android/java_bitmap.h" |
| 18 #include "url/gurl.h" | 18 #include "url/gurl.h" |
| 19 | 19 |
| 20 using base::android::JavaParamRef; | 20 using base::android::JavaParamRef; |
| 21 | 21 |
| 22 // static | 22 // static |
| 23 bool WebApkUpdateManager::Register(JNIEnv* env) { | 23 bool WebApkUpdateManager::Register(JNIEnv* env) { |
| 24 return RegisterNativesImpl(env); | 24 return RegisterNativesImpl(env); |
| 25 } | 25 } |
| 26 | 26 |
| 27 // static | 27 // static |
| 28 void WebApkUpdateManager::OnBuiltWebApk(bool success, | 28 void WebApkUpdateManager::OnBuiltWebApk(const std::string& id, |
| 29 bool success, |
| 29 const std::string& webapk_package) { | 30 const std::string& webapk_package) { |
| 30 JNIEnv* env = base::android::AttachCurrentThread(); | 31 JNIEnv* env = base::android::AttachCurrentThread(); |
| 31 | 32 |
| 32 if (success) { | 33 if (success) { |
| 33 DVLOG(1) | 34 DVLOG(1) |
| 34 << "Sent request to update WebAPK to server. Seems to have worked."; | 35 << "Sent request to update WebAPK to server. Seems to have worked."; |
| 35 } else { | 36 } else { |
| 36 LOG(WARNING) << "Server request to update WebAPK failed."; | 37 LOG(WARNING) << "Server request to update WebAPK failed."; |
| 37 } | 38 } |
| 38 | 39 |
| 39 base::android::ScopedJavaLocalRef<jstring> java_webapk_package = | 40 base::android::ScopedJavaLocalRef<jstring> java_id = |
| 40 base::android::ConvertUTF8ToJavaString(env, webapk_package); | 41 base::android::ConvertUTF8ToJavaString(env, id); |
| 41 Java_WebApkUpdateManager_onBuiltWebApk(env, success, | 42 Java_WebApkUpdateManager_onBuiltWebApk(env, java_id.obj(), success); |
| 42 java_webapk_package.obj()); | |
| 43 } | 43 } |
| 44 | 44 |
| 45 // static JNI method. | 45 // static JNI method. |
| 46 static void UpdateAsync(JNIEnv* env, | 46 static void UpdateAsync(JNIEnv* env, |
| 47 const JavaParamRef<jclass>& clazz, | 47 const JavaParamRef<jclass>& clazz, |
| 48 const JavaParamRef<jstring>& java_id, |
| 48 const JavaParamRef<jstring>& java_start_url, | 49 const JavaParamRef<jstring>& java_start_url, |
| 49 const JavaParamRef<jstring>& java_scope, | 50 const JavaParamRef<jstring>& java_scope, |
| 50 const JavaParamRef<jstring>& java_name, | 51 const JavaParamRef<jstring>& java_name, |
| 51 const JavaParamRef<jstring>& java_short_name, | 52 const JavaParamRef<jstring>& java_short_name, |
| 52 const JavaParamRef<jstring>& java_icon_url, | 53 const JavaParamRef<jstring>& java_icon_url, |
| 53 const JavaParamRef<jstring>& java_icon_murmur2_hash, | 54 const JavaParamRef<jstring>& java_icon_murmur2_hash, |
| 54 const JavaParamRef<jobject>& java_icon_bitmap, | 55 const JavaParamRef<jobject>& java_icon_bitmap, |
| 55 jint java_display_mode, | 56 jint java_display_mode, |
| 56 jint java_orientation, | 57 jint java_orientation, |
| 57 jlong java_theme_color, | 58 jlong java_theme_color, |
| 58 jlong java_background_color, | 59 jlong java_background_color, |
| 59 const JavaParamRef<jstring>& java_web_manifest_url, | 60 const JavaParamRef<jstring>& java_web_manifest_url, |
| 60 const JavaParamRef<jstring>& java_webapk_package, | 61 const JavaParamRef<jstring>& java_webapk_package, |
| 61 jint java_webapk_version) { | 62 jint java_webapk_version) { |
| 62 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 63 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| 63 | 64 |
| 64 Profile* profile = ProfileManager::GetLastUsedProfile(); | 65 Profile* profile = ProfileManager::GetLastUsedProfile(); |
| 65 if (profile == nullptr) { | 66 if (profile == nullptr) { |
| 66 NOTREACHED() << "Profile not found."; | 67 NOTREACHED() << "Profile not found."; |
| 67 return; | 68 return; |
| 68 } | 69 } |
| 69 | 70 |
| 71 std::string id(ConvertJavaStringToUTF8(env, java_id)); |
| 70 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); | 72 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); |
| 71 GURL scope(ConvertJavaStringToUTF8(env, java_scope)); | 73 GURL scope(ConvertJavaStringToUTF8(env, java_scope)); |
| 72 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url)); | 74 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url)); |
| 73 GURL icon_url(ConvertJavaStringToUTF8(env, java_icon_url)); | 75 GURL icon_url(ConvertJavaStringToUTF8(env, java_icon_url)); |
| 74 ShortcutInfo info(start_url); | 76 ShortcutInfo info(start_url); |
| 75 info.scope = scope; | 77 info.scope = scope; |
| 76 info.name = ConvertJavaStringToUTF16(env, java_name); | 78 info.name = ConvertJavaStringToUTF16(env, java_name); |
| 77 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); | 79 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); |
| 78 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); | 80 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); |
| 79 info.orientation = | 81 info.orientation = |
| 80 static_cast<blink::WebScreenOrientationLockType>(java_orientation); | 82 static_cast<blink::WebScreenOrientationLockType>(java_orientation); |
| 81 info.theme_color = (long)java_theme_color; | 83 info.theme_color = (long)java_theme_color; |
| 82 info.background_color = (long)java_background_color; | 84 info.background_color = (long)java_background_color; |
| 83 info.icon_url = icon_url; | 85 info.icon_url = icon_url; |
| 84 info.manifest_url = web_manifest_url; | 86 info.manifest_url = web_manifest_url; |
| 85 | 87 |
| 86 gfx::JavaBitmap java_bitmap_lock(java_icon_bitmap); | 88 gfx::JavaBitmap java_bitmap_lock(java_icon_bitmap); |
| 87 SkBitmap icon_bitmap = gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock); | 89 SkBitmap icon_bitmap = gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock); |
| 88 icon_bitmap.setImmutable(); | 90 icon_bitmap.setImmutable(); |
| 89 | 91 |
| 90 std::string icon_murmur2_hash; | 92 std::string icon_murmur2_hash; |
| 91 ConvertJavaStringToUTF8(env, java_icon_murmur2_hash, &icon_murmur2_hash); | 93 ConvertJavaStringToUTF8(env, java_icon_murmur2_hash, &icon_murmur2_hash); |
| 92 | 94 |
| 93 std::string webapk_package; | 95 std::string webapk_package; |
| 94 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); | 96 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); |
| 95 | 97 |
| 96 WebApkInstaller* installer = new WebApkInstaller(info, icon_bitmap); | 98 WebApkInstaller* installer = new WebApkInstaller(info, icon_bitmap); |
| 97 installer->UpdateAsync( | 99 installer->UpdateAsync( |
| 98 profile, | 100 profile, |
| 99 base::Bind(&WebApkUpdateManager::OnBuiltWebApk), | 101 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id), |
| 100 icon_murmur2_hash, webapk_package, java_webapk_version); | 102 icon_murmur2_hash, webapk_package, java_webapk_version); |
| 101 } | 103 } |
| OLD | NEW |