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 "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/location.h" | 8 #include "base/location.h" |
9 #include "base/threading/thread_task_runner_handle.h" | 9 #include "base/threading/thread_task_runner_handle.h" |
10 #include "components/offline_pages/background/request_queue_store.h" | 10 #include "components/offline_pages/background/request_queue_store.h" |
(...skipping 20 matching lines...) Expand all Loading... | |
31 void AddRequestDone(const RequestQueue::AddRequestCallback& callback, | 31 void AddRequestDone(const RequestQueue::AddRequestCallback& callback, |
32 const SavePageRequest& request, | 32 const SavePageRequest& request, |
33 RequestQueueStore::UpdateStatus status) { | 33 RequestQueueStore::UpdateStatus status) { |
34 RequestQueue::AddRequestResult result = | 34 RequestQueue::AddRequestResult result = |
35 (status == RequestQueueStore::UpdateStatus::UPDATED) | 35 (status == RequestQueueStore::UpdateStatus::UPDATED) |
36 ? RequestQueue::AddRequestResult::SUCCESS | 36 ? RequestQueue::AddRequestResult::SUCCESS |
37 : RequestQueue::AddRequestResult::STORE_FAILURE; | 37 : RequestQueue::AddRequestResult::STORE_FAILURE; |
38 callback.Run(result, request); | 38 callback.Run(result, request); |
39 } | 39 } |
40 | 40 |
41 // Completes the update request call. | |
42 void UpdateRequestDone(const RequestQueue::UpdateRequestCallback& callback, | |
43 RequestQueueStore::UpdateStatus status) { | |
44 RequestQueue::UpdateRequestResult result = | |
45 (status == RequestQueueStore::UpdateStatus::UPDATED) | |
46 ? RequestQueue::UpdateRequestResult::SUCCESS | |
47 : RequestQueue::UpdateRequestResult::STORE_FAILURE; | |
48 callback.Run(result); | |
49 } | |
50 | |
51 | |
41 // Completes the remove request call. | 52 // Completes the remove request call. |
42 void RemoveRequestDone(const RequestQueue::UpdateRequestCallback& callback, | 53 void RemoveRequestDone(const RequestQueue::UpdateRequestCallback& callback, |
43 bool success, | 54 bool success, |
44 int deleted_requests_count) { | 55 int deleted_requests_count) { |
45 DCHECK_EQ(1, deleted_requests_count); | 56 DCHECK_EQ(1, deleted_requests_count); |
46 RequestQueue::UpdateRequestResult result = | 57 RequestQueue::UpdateRequestResult result = |
47 success ? RequestQueue::UpdateRequestResult::SUCCESS | 58 success ? RequestQueue::UpdateRequestResult::SUCCESS |
48 : RequestQueue::UpdateRequestResult::STORE_FAILURE; | 59 : RequestQueue::UpdateRequestResult::STORE_FAILURE; |
49 callback.Run(result); | 60 callback.Run(result); |
50 } | 61 } |
51 } // namespace | 62 } // namespace |
52 | 63 |
53 RequestQueue::RequestQueue(std::unique_ptr<RequestQueueStore> store) | 64 RequestQueue::RequestQueue(std::unique_ptr<RequestQueueStore> store) |
54 : store_(std::move(store)) {} | 65 : store_(std::move(store)), weak_ptr_factory_(this) {} |
55 | 66 |
56 RequestQueue::~RequestQueue() {} | 67 RequestQueue::~RequestQueue() {} |
57 | 68 |
58 void RequestQueue::GetRequests(const GetRequestsCallback& callback) { | 69 void RequestQueue::GetRequests(const GetRequestsCallback& callback) { |
59 store_->GetRequests(base::Bind(&GetRequestsDone, callback)); | 70 store_->GetRequests(base::Bind(&GetRequestsDone, callback)); |
60 } | 71 } |
61 | 72 |
62 void RequestQueue::AddRequest(const SavePageRequest& request, | 73 void RequestQueue::AddRequest(const SavePageRequest& request, |
63 const AddRequestCallback& callback) { | 74 const AddRequestCallback& callback) { |
64 // TODO(fgorski): check that request makes sense. | 75 // TODO(fgorski): check that request makes sense. |
65 // TODO(fgorski): check that request does not violate policy. | 76 // TODO(fgorski): check that request does not violate policy. |
66 store_->AddOrUpdateRequest(request, | 77 store_->AddOrUpdateRequest(request, |
67 base::Bind(&AddRequestDone, callback, request)); | 78 base::Bind(&AddRequestDone, callback, request)); |
68 } | 79 } |
69 | 80 |
70 void RequestQueue::UpdateRequest(const SavePageRequest& request, | 81 void RequestQueue::UpdateRequest(const SavePageRequest& update_request, |
71 const UpdateRequestCallback& callback) {} | 82 const UpdateRequestCallback& update_callback) { |
83 // We have to pass the update_callback *through* the get callback. We do this | |
84 // by currying the update_callback as a parameter to be used when calling | |
85 // GetForUpdateDone. The actual request queue store get operation will not | |
86 // see this bound parameter, but just pass it along. GetForUpdateDone then | |
87 // passes it into the AddOrUpdateRequest method, where it ends up calling back | |
88 // to the request queue client. | |
89 store_->GetRequests(base::Bind( | |
fgorski
2016/07/22 16:14:58
This is probably going to be more efficient if we
Pete Williamson
2016/07/22 18:27:00
TODO added. crbug.com/630657.
| |
90 &RequestQueue::GetForUpdateDone, weak_ptr_factory_.GetWeakPtr(), | |
91 update_callback, update_request)); | |
92 } | |
93 | |
94 // We need a different version of the GetCallback that can take the curried | |
95 // update_callback as a parameter, and call back into the request queue store | |
96 // implementation. This must be a member function because we need access to | |
97 // the store pointer to call AddOrUpdateRequest. | |
98 void RequestQueue::GetForUpdateDone( | |
99 const UpdateRequestCallback& update_callback, | |
100 const SavePageRequest& update_request, | |
101 bool success, | |
102 const std::vector<SavePageRequest>& found_requests) { | |
103 // If the result was not found, return now. | |
104 if (!success) { | |
fgorski
2016/07/22 16:14:58
what about the case where found_request does not c
Pete Williamson
2016/07/22 18:27:00
Added case.
| |
105 update_callback.Run( | |
106 RequestQueue::UpdateRequestResult::REQUEST_DOES_NOT_EXIST); | |
107 return; | |
108 } | |
109 | |
110 // Since the request exists, update it. | |
111 store_->AddOrUpdateRequest(update_request, | |
112 base::Bind(&UpdateRequestDone, update_callback)); | |
113 } | |
72 | 114 |
73 void RequestQueue::RemoveRequest(int64_t request_id, | 115 void RequestQueue::RemoveRequest(int64_t request_id, |
74 const UpdateRequestCallback& callback) { | 116 const UpdateRequestCallback& callback) { |
75 std::vector<int64_t> request_ids{request_id}; | 117 std::vector<int64_t> request_ids{request_id}; |
76 store_->RemoveRequests(request_ids, base::Bind(RemoveRequestDone, callback)); | 118 store_->RemoveRequests(request_ids, base::Bind(RemoveRequestDone, callback)); |
77 } | 119 } |
78 | 120 |
79 void RequestQueue::PurgeRequests(const PurgeRequestsCallback& callback) {} | 121 void RequestQueue::PurgeRequests(const PurgeRequestsCallback& callback) {} |
80 | 122 |
81 } // namespace offline_pages | 123 } // namespace offline_pages |
OLD | NEW |