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

Unified Diff: remoting/protocol/pairing_registry.cc

Issue 19714002: Add serialization to PairingRegistry. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Reviewer feedback. Created 7 years, 5 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 side-by-side diff with in-line comments
Download patch
Index: remoting/protocol/pairing_registry.cc
diff --git a/remoting/protocol/pairing_registry.cc b/remoting/protocol/pairing_registry.cc
index 24875aa1ba5b43eb2a74c7adbeb74627f432ad3b..6c6b1a229127f525a021d6b77848fbe4c047546a 100644
--- a/remoting/protocol/pairing_registry.cc
+++ b/remoting/protocol/pairing_registry.cc
@@ -83,41 +83,82 @@ PairingRegistry::Pairing PairingRegistry::CreatePairing(
void PairingRegistry::GetPairing(const std::string& client_id,
const GetPairingCallback& callback) {
DCHECK(CalledOnValidThread());
- delegate_->Load(
- base::Bind(&PairingRegistry::DoGetPairing, this, client_id, callback));
+ GetPairingCallback wrapped_callback = base::Bind(
+ &PairingRegistry::InvokeGetPairingCallbackAndScheduleNext,
+ this, callback);
+ LoadCallback load_callback = base::Bind(
+ &PairingRegistry::DoGetPairing, this, client_id, wrapped_callback);
+ // |Unretained| and |get| are both safe here because the delegate is owned
+ // by the pairing registry and so is guaranteed to exist when the request
+ // is serviced.
+ base::Closure request = base::Bind(
+ &PairingRegistry::Delegate::Load,
+ base::Unretained(delegate_.get()), load_callback);
+ ServiceOrQueueRequest(request);
}
-void PairingRegistry::GetAllPairings(const GetAllPairingsCallback& callback) {
+void PairingRegistry::GetAllPairings(
+ const GetAllPairingsCallback& callback) {
DCHECK(CalledOnValidThread());
- delegate_->Load(
- base::Bind(&PairingRegistry::SanitizePairings, this, callback));
+ GetAllPairingsCallback wrapped_callback = base::Bind(
+ &PairingRegistry::InvokeGetAllPairingsCallbackAndScheduleNext,
+ this, callback);
+ LoadCallback load_callback = base::Bind(
+ &PairingRegistry::SanitizePairings, this, wrapped_callback);
+ base::Closure request = base::Bind(
+ &PairingRegistry::Delegate::Load,
+ base::Unretained(delegate_.get()), load_callback);
+ ServiceOrQueueRequest(request);
}
-void PairingRegistry::DeletePairing(const std::string& client_id,
- const SaveCallback& callback) {
+void PairingRegistry::DeletePairing(
+ const std::string& client_id, const SaveCallback& callback) {
DCHECK(CalledOnValidThread());
- delegate_->Load(
- base::Bind(&PairingRegistry::DoDeletePairing,
- this, client_id, callback));
+ SaveCallback wrapped_callback = base::Bind(
+ &PairingRegistry::InvokeSaveCallbackAndScheduleNext,
+ this, callback);
+ LoadCallback load_callback = base::Bind(
+ &PairingRegistry::DoDeletePairing, this, client_id, wrapped_callback);
+ base::Closure request = base::Bind(
+ &PairingRegistry::Delegate::Load,
+ base::Unretained(delegate_.get()), load_callback);
+ ServiceOrQueueRequest(request);
}
-void PairingRegistry::ClearAllPairings(const SaveCallback& callback) {
+void PairingRegistry::ClearAllPairings(
+ const SaveCallback& callback) {
DCHECK(CalledOnValidThread());
- delegate_->Save(EncodeJson(PairedClients()), callback);
+ SaveCallback wrapped_callback = base::Bind(
+ &PairingRegistry::InvokeSaveCallbackAndScheduleNext,
+ this, callback);
+ base::Closure request = base::Bind(
+ &PairingRegistry::Delegate::Save,
+ base::Unretained(delegate_.get()),
+ EncodeJson(PairedClients()),
+ wrapped_callback);
+ ServiceOrQueueRequest(request);
}
void PairingRegistry::AddPairing(const Pairing& pairing) {
- delegate_->Load(
- base::Bind(&PairingRegistry::MergePairingAndSave, this, pairing));
+ SaveCallback callback = base::Bind(
+ &PairingRegistry::InvokeSaveCallbackAndScheduleNext,
+ this, SaveCallback());
+ LoadCallback load_callback = base::Bind(
+ &PairingRegistry::MergePairingAndSave, this, pairing, callback);
+ base::Closure request = base::Bind(
+ &PairingRegistry::Delegate::Load,
+ base::Unretained(delegate_.get()), load_callback);
+ ServiceOrQueueRequest(request);
}
void PairingRegistry::MergePairingAndSave(const Pairing& pairing,
+ const SaveCallback& callback,
const std::string& pairings_json) {
DCHECK(CalledOnValidThread());
PairedClients clients = DecodeJson(pairings_json);
clients[pairing.client_id()] = pairing;
std::string new_pairings_json = EncodeJson(clients);
- delegate_->Save(new_pairings_json, SaveCallback());
+ delegate_->Save(new_pairings_json, callback);
}
void PairingRegistry::DoGetPairing(const std::string& client_id,
@@ -143,6 +184,38 @@ void PairingRegistry::DoDeletePairing(const std::string& client_id,
delegate_->Save(new_pairings_json, callback);
}
+void PairingRegistry::InvokeLoadCallbackAndScheduleNext(
+ const LoadCallback& callback, const std::string& pairings_json) {
+ callback.Run(pairings_json);
+ pending_requests_.pop();
+ ServiceNextRequest();
+}
+
+void PairingRegistry::InvokeSaveCallbackAndScheduleNext(
+ const SaveCallback& callback, bool success) {
+ // CreatePairing doesn't have a callback, so the callback can be null.
+ if (!callback.is_null()) {
+ callback.Run(success);
+ }
+ pending_requests_.pop();
+ ServiceNextRequest();
+}
+
+void PairingRegistry::InvokeGetPairingCallbackAndScheduleNext(
+ const GetPairingCallback& callback, Pairing pairing) {
+ callback.Run(pairing);
+ pending_requests_.pop();
+ ServiceNextRequest();
+}
+
+void PairingRegistry::InvokeGetAllPairingsCallbackAndScheduleNext(
+ const GetAllPairingsCallback& callback,
+ scoped_ptr<base::ListValue> pairings) {
+ callback.Run(pairings.Pass());
+ pending_requests_.pop();
+ ServiceNextRequest();
+}
+
// static
PairingRegistry::PairedClients PairingRegistry::DecodeJson(
const std::string& pairings_json) {
@@ -189,6 +262,22 @@ PairingRegistry::PairedClients PairingRegistry::DecodeJson(
return result;
}
+void PairingRegistry::ServiceOrQueueRequest(const base::Closure& request) {
+ bool servicing_request = !pending_requests_.empty();
+ pending_requests_.push(request);
+ if (!servicing_request) {
+ ServiceNextRequest();
+ }
+}
+
+void PairingRegistry::ServiceNextRequest() {
+ if (pending_requests_.empty()) {
+ return;
+ }
+ base::Closure request = pending_requests_.front();
+ request.Run();
Lambros 2013/07/19 01:54:21 |request| temporary not needed anymore?
Jamie 2013/07/19 02:10:13 I think it's a bit clearer than running it togethe
+}
+
// static
std::string PairingRegistry::EncodeJson(const PairedClients& clients) {
scoped_ptr<base::ListValue> root = ConvertToListValue(clients, true);

Powered by Google App Engine
This is Rietveld 408576698