| 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 #include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidati
on_handler.h" | 5 #include "chrome/browser/extensions/api/push_messaging/push_messaging_invalidati
on_handler.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/strings/string_number_conversions.h" | 10 #include "base/strings/string_number_conversions.h" |
| (...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 118 | 118 |
| 119 void PushMessagingInvalidationHandler::OnInvalidatorStateChange( | 119 void PushMessagingInvalidationHandler::OnInvalidatorStateChange( |
| 120 syncer::InvalidatorState state) { | 120 syncer::InvalidatorState state) { |
| 121 DCHECK(thread_checker_.CalledOnValidThread()); | 121 DCHECK(thread_checker_.CalledOnValidThread()); |
| 122 // Nothing to do. | 122 // Nothing to do. |
| 123 } | 123 } |
| 124 | 124 |
| 125 void PushMessagingInvalidationHandler::OnIncomingInvalidation( | 125 void PushMessagingInvalidationHandler::OnIncomingInvalidation( |
| 126 const syncer::ObjectIdInvalidationMap& invalidation_map) { | 126 const syncer::ObjectIdInvalidationMap& invalidation_map) { |
| 127 DCHECK(thread_checker_.CalledOnValidThread()); | 127 DCHECK(thread_checker_.CalledOnValidThread()); |
| 128 invalidation_map.AcknowledgeAll(); |
| 129 |
| 128 syncer::ObjectIdSet ids = invalidation_map.GetObjectIds(); | 130 syncer::ObjectIdSet ids = invalidation_map.GetObjectIds(); |
| 129 for (syncer::ObjectIdSet::const_iterator it = ids.begin(); | 131 for (syncer::ObjectIdSet::const_iterator it = ids.begin(); |
| 130 it != ids.end(); ++it) { | 132 it != ids.end(); ++it) { |
| 131 const syncer::SingleObjectInvalidationSet& list = | 133 const syncer::SingleObjectInvalidationSet& list = |
| 132 invalidation_map.ForObject(*it); | 134 invalidation_map.ForObject(*it); |
| 133 const syncer::Invalidation& invalidation = list.back(); | 135 const syncer::Invalidation& invalidation = list.back(); |
| 134 service_->AcknowledgeInvalidation(*it, invalidation.ack_handle()); | |
| 135 | 136 |
| 136 std::string payload; | 137 std::string payload; |
| 137 if (invalidation.is_unknown_version()) { | 138 if (invalidation.is_unknown_version()) { |
| 138 payload = std::string(); | 139 payload = std::string(); |
| 139 } else { | 140 } else { |
| 140 payload = list.back().payload(); | 141 payload = list.back().payload(); |
| 141 } | 142 } |
| 142 | 143 |
| 143 syncer::ObjectIdSet::iterator suppressed_id = | 144 syncer::ObjectIdSet::iterator suppressed_id = suppressed_ids_.find(*it); |
| 144 suppressed_ids_.find(*it); | |
| 145 if (suppressed_id != suppressed_ids_.end()) { | 145 if (suppressed_id != suppressed_ids_.end()) { |
| 146 suppressed_ids_.erase(suppressed_id); | 146 suppressed_ids_.erase(suppressed_id); |
| 147 continue; | 147 continue; |
| 148 } | 148 } |
| 149 DVLOG(2) << "Incoming push message, id is: " | 149 DVLOG(2) << "Incoming push message, id is: " |
| 150 << syncer::ObjectIdToString(*it) | 150 << syncer::ObjectIdToString(*it) |
| 151 << " and payload is:" << payload; | 151 << " and payload is:" << payload; |
| 152 | 152 |
| 153 std::string extension_id; | 153 std::string extension_id; |
| 154 int subchannel; | 154 int subchannel; |
| 155 if (ObjectIdToExtensionAndSubchannel(*it, &extension_id, &subchannel)) { | 155 if (ObjectIdToExtensionAndSubchannel(*it, &extension_id, &subchannel)) { |
| 156 DVLOG(2) << "Sending push message to reciever, extension is " | 156 const syncer::SingleObjectInvalidationSet& invalidation_list = |
| 157 << extension_id << ", subchannel is " << subchannel | 157 invalidation_map.ForObject(*it); |
| 158 << ", and payload is " << payload; | 158 |
| 159 delegate_->OnMessage(extension_id, subchannel, payload); | 159 // We always forward unknown version invalidation when we receive one. |
| 160 if (invalidation_list.StartsWithUnknownVersion()) { |
| 161 DVLOG(2) << "Sending push message to reciever, extension is " |
| 162 << extension_id << ", subchannel is " << subchannel |
| 163 << "and payload was lost"; |
| 164 delegate_->OnMessage(extension_id, subchannel, std::string()); |
| 165 } |
| 166 |
| 167 // If we receive a new max version for this object, forward its payload. |
| 168 const syncer::Invalidation& max_invalidation = invalidation_list.back(); |
| 169 if (!max_invalidation.is_unknown_version() && |
| 170 max_invalidation.version() > max_object_version_map_[*it]) { |
| 171 max_object_version_map_[*it] = max_invalidation.version(); |
| 172 DVLOG(2) << "Sending push message to reciever, extension is " |
| 173 << extension_id << ", subchannel is " << subchannel |
| 174 << ", and payload is " << max_invalidation.payload(); |
| 175 delegate_->OnMessage(extension_id, |
| 176 subchannel, |
| 177 max_invalidation.payload()); |
| 178 } |
| 160 } | 179 } |
| 161 } | 180 } |
| 162 } | 181 } |
| 163 | 182 |
| 164 void PushMessagingInvalidationHandler::UpdateRegistrations() { | 183 void PushMessagingInvalidationHandler::UpdateRegistrations() { |
| 165 syncer::ObjectIdSet ids; | 184 syncer::ObjectIdSet ids; |
| 166 for (std::set<std::string>::const_iterator it = | 185 for (std::set<std::string>::const_iterator it = |
| 167 registered_extensions_.begin(); it != registered_extensions_.end(); | 186 registered_extensions_.begin(); it != registered_extensions_.end(); |
| 168 ++it) { | 187 ++it) { |
| 169 const syncer::ObjectIdSet& object_ids = ExtensionIdToObjectIds(*it); | 188 const syncer::ObjectIdSet& object_ids = ExtensionIdToObjectIds(*it); |
| 170 ids.insert(object_ids.begin(), object_ids.end()); | 189 ids.insert(object_ids.begin(), object_ids.end()); |
| 171 } | 190 } |
| 172 service_->UpdateRegisteredInvalidationIds(this, ids); | 191 service_->UpdateRegisteredInvalidationIds(this, ids); |
| 173 } | 192 } |
| 174 | 193 |
| 175 } // namespace extensions | 194 } // namespace extensions |
| OLD | NEW |