| 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_array.h" | 9 #include "base/android/jni_array.h" |
| 10 #include "base/android/jni_string.h" | 10 #include "base/android/jni_string.h" |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 42 | 42 |
| 43 // static JNI method. | 43 // static JNI method. |
| 44 static void UpdateAsync( | 44 static void UpdateAsync( |
| 45 JNIEnv* env, | 45 JNIEnv* env, |
| 46 const JavaParamRef<jclass>& clazz, | 46 const JavaParamRef<jclass>& clazz, |
| 47 const JavaParamRef<jstring>& java_id, | 47 const JavaParamRef<jstring>& java_id, |
| 48 const JavaParamRef<jstring>& java_start_url, | 48 const JavaParamRef<jstring>& java_start_url, |
| 49 const JavaParamRef<jstring>& java_scope, | 49 const JavaParamRef<jstring>& java_scope, |
| 50 const JavaParamRef<jstring>& java_name, | 50 const JavaParamRef<jstring>& java_name, |
| 51 const JavaParamRef<jstring>& java_short_name, | 51 const JavaParamRef<jstring>& java_short_name, |
| 52 const JavaParamRef<jstring>& java_best_primary_icon_url, | 52 const JavaParamRef<jstring>& java_primary_icon_url, |
| 53 const JavaParamRef<jobject>& java_best_primary_icon_bitmap, | 53 const JavaParamRef<jobject>& java_primary_icon_bitmap, |
| 54 const JavaParamRef<jstring>& java_badge_icon_url, |
| 55 const JavaParamRef<jobject>& java_badge_icon_bitmap, |
| 54 const JavaParamRef<jobjectArray>& java_icon_urls, | 56 const JavaParamRef<jobjectArray>& java_icon_urls, |
| 55 const JavaParamRef<jobjectArray>& java_icon_hashes, | 57 const JavaParamRef<jobjectArray>& java_icon_hashes, |
| 56 jint java_display_mode, | 58 jint java_display_mode, |
| 57 jint java_orientation, | 59 jint java_orientation, |
| 58 jlong java_theme_color, | 60 jlong java_theme_color, |
| 59 jlong java_background_color, | 61 jlong java_background_color, |
| 60 const JavaParamRef<jstring>& java_web_manifest_url, | 62 const JavaParamRef<jstring>& java_web_manifest_url, |
| 61 const JavaParamRef<jstring>& java_webapk_package, | 63 const JavaParamRef<jstring>& java_webapk_package, |
| 62 jint java_webapk_version, | 64 jint java_webapk_version, |
| 63 jboolean java_is_manifest_stale) { | 65 jboolean java_is_manifest_stale) { |
| 64 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); | 66 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| 65 | 67 |
| 66 Profile* profile = ProfileManager::GetLastUsedProfile(); | 68 Profile* profile = ProfileManager::GetLastUsedProfile(); |
| 67 if (profile == nullptr) { | 69 if (profile == nullptr) { |
| 68 NOTREACHED() << "Profile not found."; | 70 NOTREACHED() << "Profile not found."; |
| 69 return; | 71 return; |
| 70 } | 72 } |
| 71 | 73 |
| 72 std::string id(ConvertJavaStringToUTF8(env, java_id)); | 74 std::string id(ConvertJavaStringToUTF8(env, java_id)); |
| 73 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); | 75 ShortcutInfo info(GURL(ConvertJavaStringToUTF8(env, java_start_url))); |
| 74 GURL scope(ConvertJavaStringToUTF8(env, java_scope)); | 76 info.scope = GURL(ConvertJavaStringToUTF8(env, java_scope)); |
| 75 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url)); | |
| 76 GURL best_primary_icon_url( | |
| 77 ConvertJavaStringToUTF8(env, java_best_primary_icon_url)); | |
| 78 ShortcutInfo info(start_url); | |
| 79 info.scope = scope; | |
| 80 info.name = ConvertJavaStringToUTF16(env, java_name); | 77 info.name = ConvertJavaStringToUTF16(env, java_name); |
| 81 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); | 78 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); |
| 82 info.user_title = info.short_name; | 79 info.user_title = info.short_name; |
| 83 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); | 80 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); |
| 84 info.orientation = | 81 info.orientation = |
| 85 static_cast<blink::WebScreenOrientationLockType>(java_orientation); | 82 static_cast<blink::WebScreenOrientationLockType>(java_orientation); |
| 86 info.theme_color = (int64_t)java_theme_color; | 83 info.theme_color = (int64_t)java_theme_color; |
| 87 info.background_color = (int64_t)java_background_color; | 84 info.background_color = (int64_t)java_background_color; |
| 88 info.best_primary_icon_url = best_primary_icon_url; | 85 info.best_primary_icon_url = |
| 89 info.manifest_url = web_manifest_url; | 86 GURL(ConvertJavaStringToUTF8(env, java_primary_icon_url)); |
| 87 info.best_badge_icon_url = |
| 88 GURL(ConvertJavaStringToUTF8(env, java_badge_icon_url)); |
| 89 info.manifest_url = GURL(ConvertJavaStringToUTF8(env, java_web_manifest_url)); |
| 90 | 90 |
| 91 base::android::AppendJavaStringArrayToStringVector(env, java_icon_urls.obj(), | 91 base::android::AppendJavaStringArrayToStringVector(env, java_icon_urls.obj(), |
| 92 &info.icon_urls); | 92 &info.icon_urls); |
| 93 | 93 |
| 94 std::vector<std::string> icon_hashes; | 94 std::vector<std::string> icon_hashes; |
| 95 base::android::AppendJavaStringArrayToStringVector( | 95 base::android::AppendJavaStringArrayToStringVector( |
| 96 env, java_icon_hashes.obj(), &icon_hashes); | 96 env, java_icon_hashes.obj(), &icon_hashes); |
| 97 | 97 |
| 98 std::map<std::string, std::string> icon_url_to_murmur2_hash; | 98 std::map<std::string, std::string> icon_url_to_murmur2_hash; |
| 99 for (size_t i = 0; i < info.icon_urls.size(); ++i) | 99 for (size_t i = 0; i < info.icon_urls.size(); ++i) |
| 100 icon_url_to_murmur2_hash[info.icon_urls[i]] = icon_hashes[i]; | 100 icon_url_to_murmur2_hash[info.icon_urls[i]] = icon_hashes[i]; |
| 101 | 101 |
| 102 gfx::JavaBitmap java_bitmap_lock(java_best_primary_icon_bitmap); | 102 gfx::JavaBitmap java_primary_icon_bitmap_lock(java_primary_icon_bitmap); |
| 103 SkBitmap best_primary_icon_bitmap = | 103 SkBitmap primary_icon = |
| 104 gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock); | 104 gfx::CreateSkBitmapFromJavaBitmap(java_primary_icon_bitmap_lock); |
| 105 best_primary_icon_bitmap.setImmutable(); | 105 primary_icon.setImmutable(); |
| 106 |
| 107 gfx::JavaBitmap java_badge_icon_bitmap_lock(java_badge_icon_bitmap); |
| 108 SkBitmap badge_icon = |
| 109 gfx::CreateSkBitmapFromJavaBitmap(java_badge_icon_bitmap_lock); |
| 110 badge_icon.setImmutable(); |
| 106 | 111 |
| 107 std::string webapk_package; | 112 std::string webapk_package; |
| 108 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); | 113 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); |
| 109 | 114 |
| 110 WebApkInstallService* install_service = WebApkInstallService::Get(profile); | 115 WebApkInstallService* install_service = WebApkInstallService::Get(profile); |
| 111 if (install_service->IsInstallInProgress(info.manifest_url)) { | 116 if (install_service->IsInstallInProgress(info.manifest_url)) { |
| 112 base::ThreadTaskRunnerHandle::Get()->PostTask( | 117 base::ThreadTaskRunnerHandle::Get()->PostTask( |
| 113 FROM_HERE, | 118 FROM_HERE, |
| 114 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id, | 119 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id, |
| 115 WebApkInstallResult::FAILURE, false /* relax_updates */, | 120 WebApkInstallResult::FAILURE, false /* relax_updates */, |
| 116 "" /* webapk_package */)); | 121 "" /* webapk_package */)); |
| 117 return; | 122 return; |
| 118 } | 123 } |
| 119 install_service->UpdateAsync( | 124 install_service->UpdateAsync( |
| 120 info, best_primary_icon_bitmap, webapk_package, java_webapk_version, | 125 info, primary_icon, badge_icon, webapk_package, java_webapk_version, |
| 121 icon_url_to_murmur2_hash, java_is_manifest_stale, | 126 icon_url_to_murmur2_hash, java_is_manifest_stale, |
| 122 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id)); | 127 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id)); |
| 123 } | 128 } |
| OLD | NEW |