Fire an error if a pref used in the UI is missing once all prefs are fetched.
[chromium-blink-merge.git] / chrome / browser / banners / app_banner_data_fetcher.h
blobedb534b65c2b113646052a4ae7db0d9dbca41ea3
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
3 // found in the LICENSE file.
5 #ifndef CHROME_BROWSER_BANNERS_APP_BANNER_DATA_FETCHER_H_
6 #define CHROME_BROWSER_BANNERS_APP_BANNER_DATA_FETCHER_H_
8 #include "base/memory/ref_counted.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "base/memory/weak_ptr.h"
11 #include "base/observer_list.h"
12 #include "base/time/time.h"
13 #include "chrome/browser/bitmap_fetcher/bitmap_fetcher_delegate.h"
14 #include "content/public/browser/web_contents.h"
15 #include "content/public/browser/web_contents_observer.h"
16 #include "content/public/common/manifest.h"
17 #include "third_party/WebKit/public/platform/modules/app_banner/WebAppBannerPromptReply.h"
19 namespace chrome {
20 class BitmapFetcher;
21 } // namespace chrome
23 namespace infobars {
24 class InfoBar;
25 } // namespace infobars
27 namespace banners {
28 class AppBannerDataFetcher;
30 // Fetches data required to show a web app banner for the URL currently shown by
31 // the WebContents.
32 class AppBannerDataFetcher
33 : public base::RefCounted<AppBannerDataFetcher>,
34 public chrome::BitmapFetcherDelegate,
35 public content::WebContentsObserver {
36 public:
37 class Observer {
38 public:
39 virtual void OnDecidedWhetherToShow(AppBannerDataFetcher* fetcher,
40 bool will_show) = 0;
41 virtual void OnFetcherDestroyed(AppBannerDataFetcher* fetcher) = 0;
44 class Delegate {
45 public:
46 // Called when no valid manifest was found. Returns |true| if the fetcher
47 // needs to remain active and wait for a callback.
48 virtual bool OnInvalidManifest(AppBannerDataFetcher* fetcher) = 0;
51 // Returns the current time.
52 static base::Time GetCurrentTime();
54 // Fast-forwards the current time for testing.
55 static void SetTimeDeltaForTesting(int days);
57 AppBannerDataFetcher(content::WebContents* web_contents,
58 base::WeakPtr<Delegate> weak_delegate,
59 int ideal_icon_size);
61 // Begins creating a banner for the URL being displayed by the Delegate's
62 // WebContents.
63 void Start(const GURL& validated_url);
65 // Stops the pipeline when any asynchronous calls return.
66 void Cancel();
68 // Replaces the WebContents that is being observed.
69 void ReplaceWebContents(content::WebContents* web_contents);
71 // Adds an observer to the list.
72 void AddObserverForTesting(Observer* observer);
74 // Removes an observer from the list.
75 void RemoveObserverForTesting(Observer* observer);
77 // Returns whether or not the pipeline has been stopped.
78 bool is_active() { return is_active_; }
80 // Returns the URL that kicked off the banner data retrieval.
81 const GURL& validated_url() { return validated_url_; }
83 // WebContentsObserver overrides.
84 void WebContentsDestroyed() override;
85 void DidNavigateMainFrame(
86 const content::LoadCommittedDetails& details,
87 const content::FrameNavigateParams& params) override;
88 bool OnMessageReceived(const IPC::Message& message,
89 content::RenderFrameHost* render_frame_host) override;
91 protected:
92 ~AppBannerDataFetcher() override;
94 // Return a string describing what type of banner is being created. Used when
95 // alerting websites that a banner is about to be created.
96 virtual std::string GetBannerType();
98 // Called after the manager sends a message to the renderer regarding its
99 // intention to show a prompt. The renderer will send a message back with the
100 // opportunity to cancel.
101 void OnBannerPromptReply(content::RenderFrameHost* render_frame_host,
102 int request_id,
103 blink::WebAppBannerPromptReply reply);
105 content::WebContents* GetWebContents();
106 virtual std::string GetAppIdentifier();
107 const content::Manifest& web_app_data() { return web_app_data_; }
108 void set_app_title(const base::string16& title) { app_title_ = title; }
110 // Fetches the icon at the given URL asynchronously, returning |false| if a
111 // load could not be started.
112 bool FetchIcon(const GURL& image_url);
114 // Creates a banner for the app using the given |icon|.
115 virtual infobars::InfoBar* CreateBanner(const SkBitmap* icon,
116 const base::string16& title);
118 // Records that a banner was shown. The |event_name| corresponds to the RAPPOR
119 // metric being recorded.
120 void RecordDidShowBanner(const std::string& event_name);
122 private:
123 // Callbacks for data retrieval.
124 void OnDidGetManifest(const content::Manifest& manifest);
125 void OnDidCheckHasServiceWorker(bool has_service_worker);
126 void OnFetchComplete(const GURL url, const SkBitmap* icon) override;
128 // Shows a banner for the app, if the given |icon| is valid.
129 virtual void ShowBanner(const SkBitmap* icon);
131 // Record that the banner could be shown at this point, if the triggering
132 // heuristic allowed.
133 void RecordCouldShowBanner();
135 // Returns whether the banner should be shown.
136 bool CheckIfShouldShowBanner();
138 // Returns whether the given Manifest is following the requirements to show
139 // a web app banner.
140 static bool IsManifestValid(const content::Manifest& manifest);
142 const int ideal_icon_size_;
143 const base::WeakPtr<Delegate> weak_delegate_;
144 ObserverList<Observer> observer_list_;
145 bool is_active_;
146 scoped_ptr<chrome::BitmapFetcher> bitmap_fetcher_;
147 scoped_ptr<SkBitmap> app_icon_;
149 GURL validated_url_;
150 base::string16 app_title_;
151 content::Manifest web_app_data_;
153 friend class AppBannerDataFetcherUnitTest;
154 friend class base::RefCounted<AppBannerDataFetcher>;
155 DISALLOW_COPY_AND_ASSIGN(AppBannerDataFetcher);
158 } // namespace banners
160 #endif // CHROME_BROWSER_BANNERS_APP_BANNER_DATA_FETCHER_H_