Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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 "components/offline_pages/background/request_queue.h" | 5 #include "components/offline_pages/background/request_queue.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/location.h" | 10 #include "base/location.h" |
| 11 #include "base/threading/thread_task_runner_handle.h" | 11 #include "base/threading/thread_task_runner_handle.h" |
| 12 #include "components/offline_pages/background/change_requests_state_task.h" | 12 #include "components/offline_pages/background/change_requests_state_task.h" |
| 13 #include "components/offline_pages/background/mark_attempt_aborted_task.h" | 13 #include "components/offline_pages/background/mark_attempt_aborted_task.h" |
| 14 #include "components/offline_pages/background/mark_attempt_completed_task.h" | 14 #include "components/offline_pages/background/mark_attempt_completed_task.h" |
| 15 #include "components/offline_pages/background/mark_attempt_started_task.h" | 15 #include "components/offline_pages/background/mark_attempt_started_task.h" |
| 16 #include "components/offline_pages/background/pick_request_task.h" | |
| 17 #include "components/offline_pages/background/pick_request_task_builder.h" | |
| 16 #include "components/offline_pages/background/remove_requests_task.h" | 18 #include "components/offline_pages/background/remove_requests_task.h" |
| 17 #include "components/offline_pages/background/request_queue_store.h" | 19 #include "components/offline_pages/background/request_queue_store.h" |
| 18 #include "components/offline_pages/background/save_page_request.h" | 20 #include "components/offline_pages/background/save_page_request.h" |
| 19 | 21 |
| 20 namespace offline_pages { | 22 namespace offline_pages { |
| 21 | 23 |
| 22 namespace { | 24 namespace { |
| 23 // Completes the get requests call. | 25 // Completes the get requests call. |
| 24 void GetRequestsDone(const RequestQueue::GetRequestsCallback& callback, | 26 void GetRequestsDone(const RequestQueue::GetRequestsCallback& callback, |
| 25 bool success, | 27 bool success, |
| 26 std::vector<std::unique_ptr<SavePageRequest>> requests) { | 28 std::vector<std::unique_ptr<SavePageRequest>> requests) { |
| 27 RequestQueue::GetRequestsResult result = | 29 QueueResults::GetRequestsResult result = |
| 28 success ? RequestQueue::GetRequestsResult::SUCCESS | 30 success ? QueueResults::GetRequestsResult::SUCCESS |
| 29 : RequestQueue::GetRequestsResult::STORE_FAILURE; | 31 : QueueResults::GetRequestsResult::STORE_FAILURE; |
| 30 // TODO(fgorski): Filter out expired requests based on policy. | 32 // TODO(fgorski): Filter out expired requests based on policy. |
| 31 // This may trigger the purging if necessary. | 33 // This may trigger the purging if necessary. |
| 32 // Also this may be turned into a method on the request queue or add a policy | 34 // Also this may be turned into a method on the request queue or add a policy |
| 33 // parameter in the process. | 35 // parameter in the process. |
| 34 callback.Run(result, std::move(requests)); | 36 callback.Run(result, std::move(requests)); |
| 35 } | 37 } |
| 36 | 38 |
| 37 // Completes the add request call. | 39 // Completes the add request call. |
| 38 void AddRequestDone(const RequestQueue::AddRequestCallback& callback, | 40 void AddRequestDone(const RequestQueue::AddRequestCallback& callback, |
| 39 const SavePageRequest& request, | 41 const SavePageRequest& request, |
| 40 ItemActionStatus status) { | 42 ItemActionStatus status) { |
| 41 RequestQueue::AddRequestResult result; | 43 QueueResults::AddRequestResult result; |
| 42 switch (status) { | 44 switch (status) { |
| 43 case ItemActionStatus::SUCCESS: | 45 case ItemActionStatus::SUCCESS: |
| 44 result = RequestQueue::AddRequestResult::SUCCESS; | 46 result = QueueResults::AddRequestResult::SUCCESS; |
| 45 break; | 47 break; |
| 46 case ItemActionStatus::ALREADY_EXISTS: | 48 case ItemActionStatus::ALREADY_EXISTS: |
| 47 result = RequestQueue::AddRequestResult::ALREADY_EXISTS; | 49 result = QueueResults::AddRequestResult::ALREADY_EXISTS; |
| 48 break; | 50 break; |
| 49 case ItemActionStatus::STORE_ERROR: | 51 case ItemActionStatus::STORE_ERROR: |
| 50 result = RequestQueue::AddRequestResult::STORE_FAILURE; | 52 result = QueueResults::AddRequestResult::STORE_FAILURE; |
| 51 break; | 53 break; |
| 52 case ItemActionStatus::NOT_FOUND: | 54 case ItemActionStatus::NOT_FOUND: |
| 53 default: | 55 default: |
| 54 NOTREACHED(); | 56 NOTREACHED(); |
| 55 return; | 57 return; |
| 56 } | 58 } |
| 57 callback.Run(result, request); | 59 callback.Run(result, request); |
| 58 } | 60 } |
| 59 | 61 |
| 60 } // namespace | 62 } // namespace |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 107 | 109 |
| 108 void RequestQueue::MarkAttemptCompleted(int64_t request_id, | 110 void RequestQueue::MarkAttemptCompleted(int64_t request_id, |
| 109 const UpdateCallback& callback) { | 111 const UpdateCallback& callback) { |
| 110 std::unique_ptr<Task> task( | 112 std::unique_ptr<Task> task( |
| 111 new MarkAttemptCompletedTask(store_.get(), request_id, callback)); | 113 new MarkAttemptCompletedTask(store_.get(), request_id, callback)); |
| 112 task_queue_.AddTask(std::move(task)); | 114 task_queue_.AddTask(std::move(task)); |
| 113 } | 115 } |
| 114 | 116 |
| 115 void RequestQueue::PurgeRequests(const PurgeRequestsCallback& callback) {} | 117 void RequestQueue::PurgeRequests(const PurgeRequestsCallback& callback) {} |
| 116 | 118 |
| 119 void RequestQueue::PickNextRequest( | |
| 120 PickRequestTask::RequestPickedCallback picked_callback, | |
| 121 PickRequestTask::RequestNotPickedCallback not_picked_callback, | |
| 122 DeviceConditions* conditions, | |
| 123 std::set<int64_t>& disabled_requests) { | |
| 124 // Using the PickerContext, create a picker task | |
|
fgorski
2016/11/03 22:00:29
nit: period at the end.
Pete Williamson
2016/11/04 18:53:37
Done.
| |
| 125 std::unique_ptr<Task> task(picker_builder_->CreatePickerTask( | |
| 126 this, picked_callback, not_picked_callback, conditions, | |
| 127 disabled_requests)); | |
| 128 | |
| 129 // Queue up the picking task, it will call one of the callbacks when it | |
| 130 // completes. | |
| 131 task_queue_.AddTask(std::move(task)); | |
| 132 } | |
| 133 | |
| 117 } // namespace offline_pages | 134 } // namespace offline_pages |
| OLD | NEW |