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

Side by Side Diff: chrome/browser/android/banners/app_banner_manager_android.h

Issue 2156113002: Replace AppBannerDataFetcher with InstallableManager. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@banner-refactor
Patch Set: Rebase Created 4 years, 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 #ifndef CHROME_BROWSER_ANDROID_BANNERS_APP_BANNER_MANAGER_ANDROID_H_ 5 #ifndef CHROME_BROWSER_ANDROID_BANNERS_APP_BANNER_MANAGER_ANDROID_H_
6 #define CHROME_BROWSER_ANDROID_BANNERS_APP_BANNER_MANAGER_ANDROID_H_ 6 #define CHROME_BROWSER_ANDROID_BANNERS_APP_BANNER_MANAGER_ANDROID_H_
7 7
8 #include "base/android/jni_android.h" 8 #include "base/android/jni_android.h"
9 #include "base/android/jni_weak_ref.h" 9 #include "base/android/jni_weak_ref.h"
10 #include "base/callback_forward.h"
10 #include "base/macros.h" 11 #include "base/macros.h"
11 #include "base/memory/weak_ptr.h"
12 #include "chrome/browser/android/banners/app_banner_data_fetcher_android.h"
13 #include "chrome/browser/banners/app_banner_debug_log.h"
14 #include "chrome/browser/banners/app_banner_manager.h" 12 #include "chrome/browser/banners/app_banner_manager.h"
15 #include "content/public/browser/web_contents_user_data.h" 13 #include "content/public/browser/web_contents_user_data.h"
16 14
17 namespace banners { 15 namespace banners {
18 class AppBannerDataFetcherAndroid;
19 16
20 // Extends the AppBannerManager to support native Android apps. 17 // Extends the AppBannerManager to support native Android apps.
18 // This class owns a Java-side AppBannerManager which is used to interface with
19 // the Java runtime for fetching native app data and installing them when
20 // requested.
21 // A site requests a native app banner by setting "prefer_related_applications"
22 // to true in its manifest, and providing at least one related application for
23 // the "play" platform with a Play Store ID.
24 // This class uses that information to request the app's metadata, including an
25 // icon. If successful, the icon is downloaded and the native app banner shown.
26 // Otherwise, if no related applications were detected, or their manifest
27 // entries were invalid, this class falls back to trying to verify if a web app
28 // banner is suitable.
21 class AppBannerManagerAndroid 29 class AppBannerManagerAndroid
22 : public AppBannerManager, 30 : public AppBannerManager,
23 public content::WebContentsUserData<AppBannerManagerAndroid> { 31 public content::WebContentsUserData<AppBannerManagerAndroid> {
24 public: 32 public:
25 explicit AppBannerManagerAndroid(content::WebContents* web_contents); 33 explicit AppBannerManagerAndroid(content::WebContents* web_contents);
26 ~AppBannerManagerAndroid() override; 34 ~AppBannerManagerAndroid() override;
27 35
36 // Returns a reference to the Java-side AppBannerManager owned by this object.
28 const base::android::ScopedJavaGlobalRef<jobject>& GetJavaBannerManager() 37 const base::android::ScopedJavaGlobalRef<jobject>& GetJavaBannerManager()
29 const; 38 const;
30 39
31 // Return whether a BitmapFetcher is active. 40 // Returns true if this object is currently active.
32 bool IsFetcherActive(JNIEnv* env, 41 bool IsActiveForTesting(JNIEnv* env,
33 const base::android::JavaParamRef<jobject>& jobj); 42 const base::android::JavaParamRef<jobject>& jobj);
34 43
35 // Called when the Java-side has retrieved information for the app. 44 // Called when the Java-side has retrieved information for the app.
36 // Returns |false| if an icon fetch couldn't be kicked off. 45 // Returns |false| if an icon fetch couldn't be kicked off.
37 bool OnAppDetailsRetrieved( 46 bool OnAppDetailsRetrieved(
38 JNIEnv* env, 47 JNIEnv* env,
39 const base::android::JavaParamRef<jobject>& obj, 48 const base::android::JavaParamRef<jobject>& obj,
40 const base::android::JavaParamRef<jobject>& japp_data, 49 const base::android::JavaParamRef<jobject>& japp_data,
41 const base::android::JavaParamRef<jstring>& japp_title, 50 const base::android::JavaParamRef<jstring>& japp_title,
42 const base::android::JavaParamRef<jstring>& japp_package, 51 const base::android::JavaParamRef<jstring>& japp_package,
43 const base::android::JavaParamRef<jstring>& jicon_url); 52 const base::android::JavaParamRef<jstring>& jicon_url);
44 53
54 // AppBannerManager overrides.
45 void RequestAppBanner(const GURL& validated_url, bool is_debug_mode) override; 55 void RequestAppBanner(const GURL& validated_url, bool is_debug_mode) override;
46 56
57 // Returns a callback which fetches the splash screen image and stores it in
58 // a WebappDataStorage.
59 base::Closure FetchWebappSplashScreenImageCallback(
60 const std::string& webapp_id) override;
61
47 // Registers native methods. 62 // Registers native methods.
48 static bool Register(JNIEnv* env); 63 static bool Register(JNIEnv* env);
49 64
50 protected: 65 protected:
51 AppBannerDataFetcher* CreateAppBannerDataFetcher( 66 // AppBannerManager overrides.
52 base::WeakPtr<AppBannerDataFetcher::Delegate> weak_delegate, 67 std::string GetAppIdentifier() override;
53 bool is_debug_mode) override; 68 std::string GetBannerType() override;
69 int GetIdealIconSizeInDp() override;
70 int GetMinimumIconSizeInDp() override;
71 bool IsWebAppInstalled(content::BrowserContext* browser_context,
72 const GURL& start_url) override;
73
74 void ContinueInstallableCheck() override;
75 void OnAppIconFetched(const SkBitmap& bitmap) override;
76 void ShowBanner() override;
54 77
55 private: 78 private:
56 friend class content::WebContentsUserData<AppBannerManagerAndroid>; 79 friend class content::WebContentsUserData<AppBannerManagerAndroid>;
57 80
58 // AppBannerDataFetcher::Delegate overrides. 81 // Creates the Java-side AppBannerManager.
59 bool HandleNonWebApp(const std::string& platform,
60 const GURL& url,
61 const std::string& id,
62 bool is_debug_mode) override;
63
64 void CreateJavaBannerManager(); 82 void CreateJavaBannerManager();
65 83
66 bool CheckFetcherMatchesContents(bool is_debug_mode); 84 // Returns true if |platform| and |id| are valid for querying the Play Store.
67 bool CheckPlatformAndId(const std::string& platform, 85 bool CheckPlatformAndId(const std::string& platform,
68 const std::string& id, 86 const std::string& id);
69 bool is_debug_mode);
70 87
88 // Returns the query value for |name| in |url|, e.g. example.com?name=value.
71 std::string ExtractQueryValueForName(const GURL& url, 89 std::string ExtractQueryValueForName(const GURL& url,
72 const std::string& name); 90 const std::string& name);
73 91
74 // AppBannerManager on the Java side. 92 // Returns true if |platform|, |url|, and |id| are consistent and can be used
93 // to query the Play Store for a native app. The query may not necessarily
94 // succeed (e.g. |id| doesn't map to anything), but if this method returns
95 // true, only a native app banner may be shown, and the web app banner flow
96 // will not be run.
97 bool CanHandleNonWebApp(const std::string& platform,
98 const GURL& url,
99 const std::string& id);
100
101 // The Java-side AppBannerManager.
75 base::android::ScopedJavaGlobalRef<jobject> java_banner_manager_; 102 base::android::ScopedJavaGlobalRef<jobject> java_banner_manager_;
76 103
104 // Java-side object containing data about a native app.
105 base::android::ScopedJavaGlobalRef<jobject> native_app_data_;
106
107 // App package name for a native app banner.
108 std::string native_app_package_;
109
77 DISALLOW_COPY_AND_ASSIGN(AppBannerManagerAndroid); 110 DISALLOW_COPY_AND_ASSIGN(AppBannerManagerAndroid);
78 }; // class AppBannerManagerAndroid 111 };
79 112
80 } // namespace banners 113 } // namespace banners
81 114
82 #endif // CHROME_BROWSER_ANDROID_BANNERS_APP_BANNER_MANAGER_ANDROID_H_ 115 #endif // CHROME_BROWSER_ANDROID_BANNERS_APP_BANNER_MANAGER_ANDROID_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698