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

Side by Side Diff: chrome/browser/android/webapk/webapk_update_manager.cc

Issue 2453423002: Send all of the icon URLs listed in Web Manifest to WebAPK Server. (Closed)
Patch Set: Created 4 years, 1 month 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 unified diff | Download patch
OLDNEW
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_string.h" 10 #include "base/android/jni_string.h"
10 #include "base/bind.h" 11 #include "base/bind.h"
11 #include "chrome/browser/android/webapk/webapk_installer.h" 12 #include "chrome/browser/android/webapk/webapk_installer.h"
12 #include "chrome/browser/profiles/profile.h" 13 #include "chrome/browser/profiles/profile.h"
13 #include "chrome/browser/profiles/profile_manager.h" 14 #include "chrome/browser/profiles/profile_manager.h"
14 #include "content/public/browser/browser_thread.h" 15 #include "content/public/browser/browser_thread.h"
15 #include "jni/WebApkUpdateManager_jni.h" 16 #include "jni/WebApkUpdateManager_jni.h"
16 #include "third_party/skia/include/core/SkBitmap.h" 17 #include "third_party/skia/include/core/SkBitmap.h"
17 #include "ui/gfx/android/java_bitmap.h" 18 #include "ui/gfx/android/java_bitmap.h"
18 #include "url/gurl.h" 19 #include "url/gurl.h"
(...skipping 24 matching lines...) Expand all
43 } 44 }
44 45
45 // static JNI method. 46 // static JNI method.
46 static void UpdateAsync(JNIEnv* env, 47 static void UpdateAsync(JNIEnv* env,
47 const JavaParamRef<jclass>& clazz, 48 const JavaParamRef<jclass>& clazz,
48 const JavaParamRef<jstring>& java_id, 49 const JavaParamRef<jstring>& java_id,
49 const JavaParamRef<jstring>& java_start_url, 50 const JavaParamRef<jstring>& java_start_url,
50 const JavaParamRef<jstring>& java_scope, 51 const JavaParamRef<jstring>& java_scope,
51 const JavaParamRef<jstring>& java_name, 52 const JavaParamRef<jstring>& java_name,
52 const JavaParamRef<jstring>& java_short_name, 53 const JavaParamRef<jstring>& java_short_name,
53 const JavaParamRef<jstring>& java_icon_url, 54 const JavaParamRef<jstring>& java_best_icon_url,
54 const JavaParamRef<jstring>& java_icon_murmur2_hash, 55 const JavaParamRef<jstring>& java_icon_murmur2_hash,
55 const JavaParamRef<jobject>& java_icon_bitmap, 56 const JavaParamRef<jobject>& java_icon_bitmap,
pkotwicz 2016/11/01 00:29:50 Nit: |java_icon_murmur2_hash| -> |java_best_icon_m
Xi Han 2016/11/07 16:51:43 Done.
57 const JavaParamRef<jobjectArray>& java_icon_urls,
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 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); 65 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
64 66
65 Profile* profile = ProfileManager::GetLastUsedProfile(); 67 Profile* profile = ProfileManager::GetLastUsedProfile();
66 if (profile == nullptr) { 68 if (profile == nullptr) {
67 NOTREACHED() << "Profile not found."; 69 NOTREACHED() << "Profile not found.";
68 return; 70 return;
69 } 71 }
70 72
71 std::string id(ConvertJavaStringToUTF8(env, java_id)); 73 std::string id(ConvertJavaStringToUTF8(env, java_id));
72 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); 74 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url));
73 GURL scope(ConvertJavaStringToUTF8(env, java_scope)); 75 GURL scope(ConvertJavaStringToUTF8(env, java_scope));
74 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url)); 76 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url));
75 GURL icon_url(ConvertJavaStringToUTF8(env, java_icon_url)); 77 GURL best_icon_url(ConvertJavaStringToUTF8(env, java_best_icon_url));
76 ShortcutInfo info(start_url); 78 ShortcutInfo info(start_url);
77 info.scope = scope; 79 info.scope = scope;
78 info.name = ConvertJavaStringToUTF16(env, java_name); 80 info.name = ConvertJavaStringToUTF16(env, java_name);
79 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); 81 info.short_name = ConvertJavaStringToUTF16(env, java_short_name);
80 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); 82 info.display = static_cast<blink::WebDisplayMode>(java_display_mode);
81 info.orientation = 83 info.orientation =
82 static_cast<blink::WebScreenOrientationLockType>(java_orientation); 84 static_cast<blink::WebScreenOrientationLockType>(java_orientation);
83 info.theme_color = (long)java_theme_color; 85 info.theme_color = (long)java_theme_color;
84 info.background_color = (long)java_background_color; 86 info.background_color = (long)java_background_color;
85 info.icon_url = icon_url; 87 info.best_icon_url = best_icon_url;
86 info.manifest_url = web_manifest_url; 88 info.manifest_url = web_manifest_url;
87 89
88 gfx::JavaBitmap java_bitmap_lock(java_icon_bitmap); 90 gfx::JavaBitmap java_bitmap_lock(java_icon_bitmap);
89 SkBitmap icon_bitmap = gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock); 91 SkBitmap icon_bitmap = gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock);
90 icon_bitmap.setImmutable(); 92 icon_bitmap.setImmutable();
91 93
92 std::string icon_murmur2_hash; 94 std::string icon_murmur2_hash;
93 ConvertJavaStringToUTF8(env, java_icon_murmur2_hash, &icon_murmur2_hash); 95 ConvertJavaStringToUTF8(env, java_icon_murmur2_hash, &icon_murmur2_hash);
94 96
97 std::vector<std::string> icon_urls;
98 if (!java_icon_urls.is_null()) {
99 base::android::JavaArrayOfByteArrayToStringVector(
100 env, java_icon_urls.obj(), &icon_urls);
101 }
102 for (const auto& icon_url : icon_urls)
103 info.icon_urls.push_back(GURL(icon_url));
104
95 std::string webapk_package; 105 std::string webapk_package;
96 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); 106 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package);
97 107
98 WebApkInstaller* installer = new WebApkInstaller(info, icon_bitmap); 108 WebApkInstaller* installer = new WebApkInstaller(info, icon_bitmap);
99 installer->UpdateAsync( 109 installer->UpdateAsync(
100 profile, 110 profile,
101 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id), 111 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id),
102 icon_murmur2_hash, webapk_package, java_webapk_version); 112 icon_murmur2_hash, webapk_package, java_webapk_version);
103 } 113 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698