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

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: Use String[] for icon urls. 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 17 matching lines...) Expand all
36 } else { 37 } else {
37 LOG(WARNING) << "Server request to update WebAPK failed."; 38 LOG(WARNING) << "Server request to update WebAPK failed.";
38 } 39 }
39 40
40 base::android::ScopedJavaLocalRef<jstring> java_id = 41 base::android::ScopedJavaLocalRef<jstring> java_id =
41 base::android::ConvertUTF8ToJavaString(env, id); 42 base::android::ConvertUTF8ToJavaString(env, id);
42 Java_WebApkUpdateManager_onBuiltWebApk(env, java_id.obj(), success); 43 Java_WebApkUpdateManager_onBuiltWebApk(env, java_id.obj(), success);
43 } 44 }
44 45
45 // static JNI method. 46 // static JNI method.
46 static void UpdateAsync(JNIEnv* env, 47 static void UpdateAsync(
47 const JavaParamRef<jclass>& clazz, 48 JNIEnv* env,
48 const JavaParamRef<jstring>& java_id, 49 const JavaParamRef<jclass>& clazz,
49 const JavaParamRef<jstring>& java_start_url, 50 const JavaParamRef<jstring>& java_id,
50 const JavaParamRef<jstring>& java_scope, 51 const JavaParamRef<jstring>& java_start_url,
51 const JavaParamRef<jstring>& java_name, 52 const JavaParamRef<jstring>& java_scope,
52 const JavaParamRef<jstring>& java_short_name, 53 const JavaParamRef<jstring>& java_name,
53 const JavaParamRef<jstring>& java_icon_url, 54 const JavaParamRef<jstring>& java_short_name,
54 const JavaParamRef<jstring>& java_icon_murmur2_hash, 55 const JavaParamRef<jstring>& java_best_icon_url,
55 const JavaParamRef<jobject>& java_icon_bitmap, 56 const JavaParamRef<jstring>& java_best_icon_murmur2_hash,
56 jint java_display_mode, 57 const JavaParamRef<jobject>& java_best_icon_bitmap,
57 jint java_orientation, 58 const JavaParamRef<jobjectArray>& java_icon_urls,
58 jlong java_theme_color, 59 jint java_display_mode,
59 jlong java_background_color, 60 jint java_orientation,
60 const JavaParamRef<jstring>& java_web_manifest_url, 61 jlong java_theme_color,
61 const JavaParamRef<jstring>& java_webapk_package, 62 jlong java_background_color,
62 jint java_webapk_version) { 63 const JavaParamRef<jstring>& java_web_manifest_url,
64 const JavaParamRef<jstring>& java_webapk_package,
65 jint java_webapk_version) {
63 DCHECK_CURRENTLY_ON(content::BrowserThread::UI); 66 DCHECK_CURRENTLY_ON(content::BrowserThread::UI);
64 67
65 Profile* profile = ProfileManager::GetLastUsedProfile(); 68 Profile* profile = ProfileManager::GetLastUsedProfile();
66 if (profile == nullptr) { 69 if (profile == nullptr) {
67 NOTREACHED() << "Profile not found."; 70 NOTREACHED() << "Profile not found.";
68 return; 71 return;
69 } 72 }
70 73
71 std::string id(ConvertJavaStringToUTF8(env, java_id)); 74 std::string id(ConvertJavaStringToUTF8(env, java_id));
72 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url)); 75 GURL start_url(ConvertJavaStringToUTF8(env, java_start_url));
73 GURL scope(ConvertJavaStringToUTF8(env, java_scope)); 76 GURL scope(ConvertJavaStringToUTF8(env, java_scope));
74 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url)); 77 GURL web_manifest_url(ConvertJavaStringToUTF8(env, java_web_manifest_url));
75 GURL icon_url(ConvertJavaStringToUTF8(env, java_icon_url)); 78 GURL best_icon_url(ConvertJavaStringToUTF8(env, java_best_icon_url));
76 ShortcutInfo info(start_url); 79 ShortcutInfo info(start_url);
77 info.scope = scope; 80 info.scope = scope;
78 info.name = ConvertJavaStringToUTF16(env, java_name); 81 info.name = ConvertJavaStringToUTF16(env, java_name);
79 info.short_name = ConvertJavaStringToUTF16(env, java_short_name); 82 info.short_name = ConvertJavaStringToUTF16(env, java_short_name);
80 info.display = static_cast<blink::WebDisplayMode>(java_display_mode); 83 info.display = static_cast<blink::WebDisplayMode>(java_display_mode);
81 info.orientation = 84 info.orientation =
82 static_cast<blink::WebScreenOrientationLockType>(java_orientation); 85 static_cast<blink::WebScreenOrientationLockType>(java_orientation);
83 info.theme_color = (long)java_theme_color; 86 info.theme_color = (long)java_theme_color;
84 info.background_color = (long)java_background_color; 87 info.background_color = (long)java_background_color;
85 info.icon_url = icon_url; 88 info.best_icon_url = best_icon_url;
86 info.manifest_url = web_manifest_url; 89 info.manifest_url = web_manifest_url;
87 90
88 gfx::JavaBitmap java_bitmap_lock(java_icon_bitmap); 91 std::vector<std::string> icon_urls;
89 SkBitmap icon_bitmap = gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock); 92 base::android::JavaArrayOfByteArrayToStringVector(
dominickn 2016/11/17 21:16:43 Can this just be base::android::JavaArrayOfByteAr
Xi Han 2016/11/17 21:34:10 Done.
90 icon_bitmap.setImmutable(); 93 env, java_icon_urls.obj(), &icon_urls);
94 for (const auto& icon_url : icon_urls)
95 info.icon_urls.push_back(icon_url);
91 96
92 std::string icon_murmur2_hash; 97
93 ConvertJavaStringToUTF8(env, java_icon_murmur2_hash, &icon_murmur2_hash); 98 gfx::JavaBitmap java_bitmap_lock(java_best_icon_bitmap);
99 SkBitmap best_icon_bitmap =
100 gfx::CreateSkBitmapFromJavaBitmap(java_bitmap_lock);
101 best_icon_bitmap.setImmutable();
102
103 std::string best_icon_murmur2_hash;
104 ConvertJavaStringToUTF8(env, java_best_icon_murmur2_hash,
105 &best_icon_murmur2_hash);
94 106
95 std::string webapk_package; 107 std::string webapk_package;
96 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package); 108 ConvertJavaStringToUTF8(env, java_webapk_package, &webapk_package);
97 109
98 WebApkInstaller* installer = new WebApkInstaller(info, icon_bitmap); 110 WebApkInstaller* installer = new WebApkInstaller(info, best_icon_bitmap);
99 installer->UpdateAsync( 111 installer->UpdateAsync(
100 profile, 112 profile,
101 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id), 113 base::Bind(&WebApkUpdateManager::OnBuiltWebApk, id),
102 icon_murmur2_hash, webapk_package, java_webapk_version); 114 best_icon_murmur2_hash, webapk_package, java_webapk_version);
103 } 115 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698