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

Side by Side Diff: components/doodle/doodle_fetcher.h

Issue 2660883002: Introduce a Doodle Fetcher for NTP (Closed)
Patch Set: Removed unnecessary constructor. Created 3 years, 10 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
(Empty)
1 // Copyright 2017 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.
4
5 #ifndef COMPONENTS_DOODLE_DOODLE_FETCHER_H_
6 #define COMPONENTS_DOODLE_DOODLE_FETCHER_H_
7
8 #include <memory>
9 #include <string>
10 #include <utility>
11 #include <vector>
12
13 #include "base/callback.h"
14 #include "base/macros.h"
15 #include "base/memory/weak_ptr.h"
16 #include "base/optional.h"
17 #include "net/url_request/url_fetcher_delegate.h"
18 #include "url/gurl.h"
19
20 class GoogleURLTracker;
21
22 namespace base {
23 class Clock;
24 class DictionaryValue;
25 class Value;
26 }
27
28 namespace net {
29 class URLRequestContextGetter;
30 }
31
32 namespace doodle {
33
34 enum class DoodleState {
35 AVAILABLE,
36 NO_DOODLE,
37 DOWNLOAD_ERROR,
38 PARSING_ERROR,
39 };
40
41 enum class DoodleType {
42 UNKNOWN,
43 SIMPLE,
44 RANDOM,
45 VIDEO,
46 INTERACTIVE,
47 INLINE_INTERACTIVE,
48 SLIDESHOW,
49 };
50
51 // Information about a Doodle image. If the image is invalid, the |url| will be
52 // empty and invalid. By default the dimensions are 0.
53 struct DoodleImage {
54 DoodleImage();
55 ~DoodleImage();
56
57 GURL url;
58 int height;
59 int width;
60 bool is_animated_gif;
61 bool is_cta;
62
63 // Copying and assignment allowed.
64 };
65
66 // All information about a current doodle that can be fetched from the remote
67 // end. By default, all URLs are empty and therefore invalid.
68 struct DoodleConfig {
69 DoodleConfig();
70 DoodleConfig(const DoodleConfig& config); // = default;
71 ~DoodleConfig();
72
73 DoodleType doodle_type;
74 std::string alt_text;
75 std::string interactive_html;
76
77 base::Time expiry_date;
78 GURL search_url;
79 GURL target_url;
80 GURL fullpage_interactive_url;
81
82 DoodleImage large_image;
83 DoodleImage large_cta_image;
84 DoodleImage transparent_large_image;
85 };
86
87 // This class provides information about any recent doodle.
88 // It works asynchronously and calls a callback when finished fetching the
89 // information from the remote enpoint.
90 class DoodleFetcher : public net::URLFetcherDelegate {
91 public:
92 // Callback that is invoked when the fetching is done.
93 // |doodle_config| will only contain a value if |state| is AVAILABLE.
94 using FinishedCallback = base::OnceCallback<void(
95 DoodleState state,
96 const base::Optional<DoodleConfig>& doodle_config)>;
97 // Callback for JSON parsing to allow injecting platform-dependent code.
98 using ParseJSONCallback = base::Callback<void(
99 const std::string& unsafe_json,
100 const base::Callback<void(std::unique_ptr<base::Value> json)>& success,
101 const base::Callback<void(const std::string&)>& error)>;
102
103 DoodleFetcher(net::URLRequestContextGetter* download_context,
mattm 2017/02/14 22:37:14 In practice, which context will this be? The profi
Marc Treib 2017/02/15 09:07:22 Yes, this will be per-profile. Right now, we don't
104 GoogleURLTracker* google_url_tracker,
105 const ParseJSONCallback& json_parsing_callback);
106 ~DoodleFetcher() override;
107
108 // Fetches a doodle asynchronously. The |callback| is called with a
109 // DoodleState indicating whether the request succeded in fetching a doodle.
110 // If a fetch is already running, the callback will be queued and invoked with
111 // result from the next completed request.
112 void FetchDoodle(FinishedCallback callback);
113
114 // Overrides internal clock for testing purposes.
115 void SetClockForTesting(std::unique_ptr<base::Clock> clock) {
116 clock_ = std::move(clock);
117 }
118
119 private:
120 // net::URLFetcherDelegate implementation.
121 void OnURLFetchComplete(const net::URLFetcher* source) override;
122
123 // ParseJSONCallback Success callback
124 void OnJsonParsed(std::unique_ptr<base::Value> json);
125 // ParseJSONCallback Failure callback
126 void OnJsonParseFailed(const std::string& error_message);
127
128 base::Optional<DoodleConfig> ParseDoodle(
129 const base::DictionaryValue& ddljson) const;
130 bool ParseImage(const base::DictionaryValue& image_dict,
131 const std::string& image_name,
132 DoodleImage* image) const;
133 void ParseBaseInformation(const base::DictionaryValue& ddljson,
134 DoodleConfig* config) const;
135 GURL ParseRelativeUrl(const base::DictionaryValue& dict_value,
136 const std::string& key) const;
137
138 void RespondToAllCallbacks(DoodleState state,
139 const base::Optional<DoodleConfig>& config);
140 GURL GetGoogleBaseUrl() const;
141
142 // Returns whether a fetch is still in progress. A fetch begins when a
143 // callback is added and ends when the last callback was called.
144 bool IsFetchInProgress() const { return !callbacks_.empty(); }
145
146 // Parameters set from constructor.
147 net::URLRequestContextGetter* const download_context_;
mattm 2017/02/14 22:37:14 scoped_refptr
fhorschig 2017/02/15 10:49:51 Done.
148 ParseJSONCallback json_parsing_callback_;
149 GoogleURLTracker* google_url_tracker_;
150
151 // Allow for an injectable tick clock for testing.
152 std::unique_ptr<base::Clock> clock_;
153
154 std::vector<FinishedCallback> callbacks_;
155 std::unique_ptr<net::URLFetcher> fetcher_;
156
157 base::WeakPtrFactory<DoodleFetcher> weak_ptr_factory_;
158
159 DISALLOW_COPY_AND_ASSIGN(DoodleFetcher);
160 };
161
162 } // namespace doodle
163
164 #endif // COMPONENTS_DOODLE_DOODLE_FETCHER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698