OLD | NEW |
1 // Copyright 2012 The Chromium Authors. All rights reserved. | 1 // Copyright 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 #include "chrome/browser/component_updater/component_updater_service.h" | 5 #include "chrome/browser/component_updater/component_updater_service.h" |
6 | 6 |
7 #include <algorithm> | 7 #include <algorithm> |
8 #include <set> | 8 #include <set> |
9 #include <vector> | 9 #include <vector> |
10 | 10 |
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
194 void OnUpdateCheckSucceeded(const UpdateResponse::Results& results); | 194 void OnUpdateCheckSucceeded(const UpdateResponse::Results& results); |
195 void OnUpdateCheckFailed(int error, const std::string& error_message); | 195 void OnUpdateCheckFailed(int error, const std::string& error_message); |
196 | 196 |
197 void DownloadProgress(const std::string& component_id, | 197 void DownloadProgress(const std::string& component_id, |
198 const CrxDownloader::Result& download_result); | 198 const CrxDownloader::Result& download_result); |
199 | 199 |
200 void DownloadComplete(scoped_ptr<CRXContext> crx_context, | 200 void DownloadComplete(scoped_ptr<CRXContext> crx_context, |
201 const CrxDownloader::Result& download_result); | 201 const CrxDownloader::Result& download_result); |
202 | 202 |
203 Status OnDemandUpdateInternal(CrxUpdateItem* item); | 203 Status OnDemandUpdateInternal(CrxUpdateItem* item); |
| 204 Status OnDemandUpdateWithCooldown(CrxUpdateItem* item); |
204 | 205 |
205 void ProcessPendingItems(); | 206 void ProcessPendingItems(); |
206 | 207 |
207 // Find a component that is ready to update. | 208 // Find a component that is ready to update. |
208 CrxUpdateItem* FindReadyComponent() const; | 209 CrxUpdateItem* FindReadyComponent() const; |
209 | 210 |
210 // Prepares the components for an update check and initiates the request. | 211 // Prepares the components for an update check and initiates the request. |
211 // Returns true if an update check request has been made. Returns false if | 212 // Returns true if an update check request has been made. Returns false if |
212 // no update check was needed or an error occured. | 213 // no update check was needed or an error occured. |
213 bool CheckForUpdates(); | 214 bool CheckForUpdates(); |
(...skipping 735 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
949 crx_id)); | 950 crx_id)); |
950 return rt; | 951 return rt; |
951 } | 952 } |
952 | 953 |
953 void CrxUpdateService::OnNewResourceThrottle( | 954 void CrxUpdateService::OnNewResourceThrottle( |
954 base::WeakPtr<CUResourceThrottle> rt, | 955 base::WeakPtr<CUResourceThrottle> rt, |
955 const std::string& crx_id) { | 956 const std::string& crx_id) { |
956 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 957 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
957 // Check if we can on-demand update, else unblock the request anyway. | 958 // Check if we can on-demand update, else unblock the request anyway. |
958 CrxUpdateItem* item = FindUpdateItemById(crx_id); | 959 CrxUpdateItem* item = FindUpdateItemById(crx_id); |
959 Status status = OnDemandUpdateInternal(item); | 960 Status status = OnDemandUpdateWithCooldown(item); |
960 if (status == kOk || status == kInProgress) { | 961 if (status == kOk || status == kInProgress) { |
961 item->throttles.push_back(rt); | 962 item->throttles.push_back(rt); |
962 return; | 963 return; |
963 } | 964 } |
964 UnblockResourceThrottle(rt); | 965 UnblockResourceThrottle(rt); |
965 } | 966 } |
966 | 967 |
967 // Start the process of checking for an update, for a particular component | 968 // Start the process of checking for an update, for a particular component |
968 // that was previously registered. | 969 // that was previously registered. |
969 // |component_id| is a value returned from GetCrxComponentID(). | 970 // |component_id| is a value returned from GetCrxComponentID(). |
970 ComponentUpdateService::Status CrxUpdateService::OnDemandUpdate( | 971 ComponentUpdateService::Status CrxUpdateService::OnDemandUpdate( |
971 const std::string& component_id) { | 972 const std::string& component_id) { |
972 return OnDemandUpdateInternal(FindUpdateItemById(component_id)); | 973 return OnDemandUpdateInternal(FindUpdateItemById(component_id)); |
973 } | 974 } |
974 | 975 |
975 ComponentUpdateService::Status CrxUpdateService::OnDemandUpdateInternal( | 976 ComponentUpdateService::Status CrxUpdateService::OnDemandUpdateWithCooldown( |
976 CrxUpdateItem* uit) { | 977 CrxUpdateItem* uit) { |
977 if (!uit) | 978 if (!uit) |
978 return kError; | 979 return kError; |
979 | 980 |
980 // Check if the request is too soon. | 981 // Check if the request is too soon. |
981 base::TimeDelta delta = base::Time::Now() - uit->last_check; | 982 base::TimeDelta delta = base::Time::Now() - uit->last_check; |
982 if (delta < base::TimeDelta::FromSeconds(config_->OnDemandDelay())) | 983 if (delta < base::TimeDelta::FromSeconds(config_->OnDemandDelay())) |
983 return kError; | 984 return kError; |
984 | 985 |
| 986 return OnDemandUpdateInternal(uit); |
| 987 } |
| 988 |
| 989 ComponentUpdateService::Status CrxUpdateService::OnDemandUpdateInternal( |
| 990 CrxUpdateItem* uit) { |
| 991 if (!uit) |
| 992 return kError; |
| 993 |
985 Status service_status = GetServiceStatus(uit->status); | 994 Status service_status = GetServiceStatus(uit->status); |
986 // If the item is already in the process of being updated, there is | 995 // If the item is already in the process of being updated, there is |
987 // no point in this call, so return kInProgress. | 996 // no point in this call, so return kInProgress. |
988 if (service_status == kInProgress) | 997 if (service_status == kInProgress) |
989 return service_status; | 998 return service_status; |
990 | 999 |
991 // Otherwise the item was already checked a while back (or it is new), | 1000 // Otherwise the item was already checked a while back (or it is new), |
992 // set its status to kNew to give it a slightly higher priority. | 1001 // set its status to kNew to give it a slightly higher priority. |
993 ChangeItemState(uit, CrxUpdateItem::kNew); | 1002 ChangeItemState(uit, CrxUpdateItem::kNew); |
994 uit->on_demand = true; | 1003 uit->on_demand = true; |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1064 | 1073 |
1065 // The component update factory. Using the component updater as a singleton | 1074 // The component update factory. Using the component updater as a singleton |
1066 // is the job of the browser process. | 1075 // is the job of the browser process. |
1067 ComponentUpdateService* ComponentUpdateServiceFactory( | 1076 ComponentUpdateService* ComponentUpdateServiceFactory( |
1068 ComponentUpdateService::Configurator* config) { | 1077 ComponentUpdateService::Configurator* config) { |
1069 DCHECK(config); | 1078 DCHECK(config); |
1070 return new CrxUpdateService(config); | 1079 return new CrxUpdateService(config); |
1071 } | 1080 } |
1072 | 1081 |
1073 } // namespace component_updater | 1082 } // namespace component_updater |
OLD | NEW |