OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 COMPONENTS_HISTORY_CORE_BROWSER_WEB_HISTORY_SERVICE_H_ | 5 #ifndef CHROME_BROWSER_HISTORY_WEB_HISTORY_SERVICE_H_ |
6 #define COMPONENTS_HISTORY_CORE_BROWSER_WEB_HISTORY_SERVICE_H_ | 6 #define CHROME_BROWSER_HISTORY_WEB_HISTORY_SERVICE_H_ |
7 | 7 |
8 #include <set> | 8 #include <set> |
9 #include <string> | |
10 #include <vector> | |
11 | 9 |
12 #include "base/memory/ref_counted.h" | |
13 #include "base/memory/weak_ptr.h" | 10 #include "base/memory/weak_ptr.h" |
| 11 #include "chrome/browser/profiles/profile.h" |
14 #include "components/history/core/browser/history_types.h" | 12 #include "components/history/core/browser/history_types.h" |
15 #include "components/keyed_service/core/keyed_service.h" | 13 #include "components/keyed_service/core/keyed_service.h" |
16 | 14 |
17 namespace base { | 15 namespace base { |
18 class DictionaryValue; | 16 class DictionaryValue; |
19 } | 17 } |
20 | 18 |
21 namespace net { | 19 namespace net { |
22 class URLRequestContextGetter; | 20 class URLFetcher; |
23 } | 21 } |
24 | 22 |
25 class OAuth2TokenService; | |
26 class SigninManagerBase; | |
27 | |
28 namespace history { | 23 namespace history { |
29 | 24 |
30 // Provides an API for querying Google servers for a signed-in user's | 25 // Provides an API for querying Google servers for a signed-in user's |
31 // synced history visits. It is roughly analogous to HistoryService, and | 26 // synced history visits. It is roughly analogous to HistoryService, and |
32 // supports a similar API. | 27 // supports a similar API. |
33 class WebHistoryService : public KeyedService { | 28 class WebHistoryService : public KeyedService { |
34 public: | 29 public: |
35 // Handles all the work of making an API request. This class encapsulates | 30 // Handles all the work of making an API request. This class encapsulates |
36 // the entire state of the request. When an instance is destroyed, all | 31 // the entire state of the request. When an instance is destroyed, all |
37 // aspects of the request are cancelled. | 32 // aspects of the request are cancelled. |
(...skipping 27 matching lines...) Expand all Loading... |
65 typedef base::Callback<void(Request*, const base::DictionaryValue*)> | 60 typedef base::Callback<void(Request*, const base::DictionaryValue*)> |
66 QueryWebHistoryCallback; | 61 QueryWebHistoryCallback; |
67 | 62 |
68 typedef base::Callback<void(bool success)> ExpireWebHistoryCallback; | 63 typedef base::Callback<void(bool success)> ExpireWebHistoryCallback; |
69 | 64 |
70 typedef base::Callback<void(bool success, bool new_enabled_value)> | 65 typedef base::Callback<void(bool success, bool new_enabled_value)> |
71 AudioWebHistoryCallback; | 66 AudioWebHistoryCallback; |
72 | 67 |
73 typedef base::Callback<void(Request*, bool success)> CompletionCallback; | 68 typedef base::Callback<void(Request*, bool success)> CompletionCallback; |
74 | 69 |
75 WebHistoryService( | 70 explicit WebHistoryService(Profile* profile); |
76 OAuth2TokenService* token_service, | |
77 SigninManagerBase* signin_manager, | |
78 const scoped_refptr<net::URLRequestContextGetter>& request_context); | |
79 ~WebHistoryService() override; | 71 ~WebHistoryService() override; |
80 | 72 |
81 // Searches synced history for visits matching |text_query|. The timeframe to | 73 // Searches synced history for visits matching |text_query|. The timeframe to |
82 // search, along with other options, is specified in |options|. If | 74 // search, along with other options, is specified in |options|. If |
83 // |text_query| is empty, all visits in the timeframe will be returned. | 75 // |text_query| is empty, all visits in the timeframe will be returned. |
84 // This method is the equivalent of HistoryService::QueryHistory. | 76 // This method is the equivalent of HistoryService::QueryHistory. |
85 // The caller takes ownership of the returned Request. If it is destroyed, the | 77 // The caller takes ownership of the returned Request. If it is destroyed, the |
86 // request is cancelled. | 78 // request is cancelled. |
87 scoped_ptr<Request> QueryHistory( | 79 scoped_ptr<Request> QueryHistory( |
88 const base::string16& text_query, | 80 const base::string16& text_query, |
(...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
142 // server has completed. Unpacks the response and calls |callback|, which is | 134 // server has completed. Unpacks the response and calls |callback|, which is |
143 // the original callback that was passed to AudioHistory(). | 135 // the original callback that was passed to AudioHistory(). |
144 void AudioHistoryCompletionCallback( | 136 void AudioHistoryCompletionCallback( |
145 const WebHistoryService::AudioWebHistoryCallback& callback, | 137 const WebHistoryService::AudioWebHistoryCallback& callback, |
146 WebHistoryService::Request* request, | 138 WebHistoryService::Request* request, |
147 bool success); | 139 bool success); |
148 | 140 |
149 private: | 141 private: |
150 friend class WebHistoryServiceTest; | 142 friend class WebHistoryServiceTest; |
151 | 143 |
152 // Stores pointer to OAuth2TokenService and SigninManagerBase instance. They | 144 Profile* profile_; |
153 // must outlive the WebHistoryService and can be null during tests. | |
154 OAuth2TokenService* token_service_; | |
155 SigninManagerBase* signin_manager_; | |
156 | |
157 // Request context getter to use. | |
158 scoped_refptr<net::URLRequestContextGetter> request_context_; | |
159 | 145 |
160 // Stores the version_info token received from the server in response to | 146 // Stores the version_info token received from the server in response to |
161 // a mutation operation (e.g., deleting history). This is used to ensure that | 147 // a mutation operation (e.g., deleting history). This is used to ensure that |
162 // subsequent reads see a version of the data that includes the mutation. | 148 // subsequent reads see a version of the data that includes the mutation. |
163 std::string server_version_info_; | 149 std::string server_version_info_; |
164 | 150 |
165 // Pending expiration requests to be canceled if not complete by profile | 151 // Pending expiration requests to be canceled if not complete by profile |
166 // shutdown. | 152 // shutdown. |
167 std::set<Request*> pending_expire_requests_; | 153 std::set<Request*> pending_expire_requests_; |
168 | 154 |
169 // Pending requests to be canceled if not complete by profile shutdown. | 155 // Pending requests to be canceled if not complete by profile shutdown. |
170 std::set<Request*> pending_audio_history_requests_; | 156 std::set<Request*> pending_audio_history_requests_; |
171 | 157 |
172 base::WeakPtrFactory<WebHistoryService> weak_ptr_factory_; | 158 base::WeakPtrFactory<WebHistoryService> weak_ptr_factory_; |
173 | 159 |
174 DISALLOW_COPY_AND_ASSIGN(WebHistoryService); | 160 DISALLOW_COPY_AND_ASSIGN(WebHistoryService); |
175 }; | 161 }; |
176 | 162 |
177 } // namespace history | 163 } // namespace history |
178 | 164 |
179 #endif // COMPONENTS_HISTORY_CORE_BROWSER_WEB_HISTORY_SERVICE_H_ | 165 #endif // CHROME_BROWSER_HISTORY_WEB_HISTORY_SERVICE_H_ |
OLD | NEW |