| Index: chrome/browser/invalidation/invalidation_service_android.cc
|
| diff --git a/chrome/browser/invalidation/invalidation_service_android.cc b/chrome/browser/invalidation/invalidation_service_android.cc
|
| index b12f1237388bc1cb7879037c64cfd7d49f717e54..8ccac1c8780b4813d0bb54cb9f71515bae32ae12 100644
|
| --- a/chrome/browser/invalidation/invalidation_service_android.cc
|
| +++ b/chrome/browser/invalidation/invalidation_service_android.cc
|
| @@ -4,8 +4,11 @@
|
|
|
| #include "chrome/browser/invalidation/invalidation_service_android.h"
|
|
|
| +#include "base/android/jni_array.h"
|
| #include "chrome/browser/chrome_notification_types.h"
|
| #include "content/public/browser/notification_service.h"
|
| +#include "google/cacheinvalidation/types.pb.h"
|
| +#include "sync/jni/InvalidationController_jni.h"
|
|
|
| namespace invalidation {
|
|
|
| @@ -28,7 +31,13 @@ void InvalidationServiceAndroid::UpdateRegisteredInvalidationIds(
|
| syncer::InvalidationHandler* handler,
|
| const syncer::ObjectIdSet& ids) {
|
| DCHECK(CalledOnValidThread());
|
| + // Registration with the Android invalidation controller is needed if any of
|
| + // the objects in the current or replacement object sets require it.
|
| + bool isRegistrationRequired = IsRegistrationRequired(ids) ||
|
| + IsRegistrationRequired(invalidator_registrar_.GetRegisteredIds(handler));
|
| invalidator_registrar_.UpdateRegisteredIds(handler, ids);
|
| + if (isRegistrationRequired)
|
| + UpdateRegistration();
|
| }
|
|
|
| void InvalidationServiceAndroid::UnregisterInvalidationHandler(
|
| @@ -88,4 +97,65 @@ void InvalidationServiceAndroid::TriggerStateChangeForTest(
|
| invalidator_registrar_.UpdateInvalidatorState(invalidator_state_);
|
| }
|
|
|
| +void InvalidationServiceAndroid::SetUpdateRegistrationCallbackForTest(
|
| + const UpdateRegistrationCallback& callback) {
|
| + update_registration_callback_ = callback;
|
| +}
|
| +
|
| +void InvalidationServiceAndroid::UpdateRegistration() {
|
| + // Create a list of object sources and names which require registration.
|
| + std::vector<int> sources;
|
| + std::vector<std::string> names;
|
| + syncer::ObjectIdSet ids = invalidator_registrar_.GetAllRegisteredIds();
|
| + syncer::ObjectIdSet::const_iterator id;
|
| + for (id = ids.begin(); id != ids.end(); ++id) {
|
| + if (IsRegistrationRequired(*id)) {
|
| + sources.push_back(id->source());
|
| + names.push_back(id->name());
|
| + }
|
| + }
|
| +
|
| + // Invoke callback for testing if provided.
|
| + if (!update_registration_callback_.is_null()) {
|
| + update_registration_callback_.Run(sources, names);
|
| + return;
|
| + }
|
| +
|
| + // Get a reference to the invalidation controller.
|
| + JNIEnv* env = base::android::AttachCurrentThread();
|
| + DCHECK(env);
|
| + if (invalidation_controller_.is_null()) {
|
| + invalidation_controller_.Reset(Java_InvalidationController_get(
|
| + env,
|
| + base::android::GetApplicationContext()));
|
| + }
|
| +
|
| + // Update the registration with the invalidation controller.
|
| + Java_InvalidationController_setRegisteredObjectIds(
|
| + env,
|
| + invalidation_controller_.obj(),
|
| + base::android::ToJavaIntArray(env, sources).obj(),
|
| + base::android::ToJavaArrayOfStrings(env, names).obj());
|
| +}
|
| +
|
| +bool InvalidationServiceAndroid::IsRegistrationRequired(
|
| + const syncer::ObjectIdSet& ids) {
|
| + syncer::ObjectIdSet::const_iterator id;
|
| + for (id = ids.begin(); id != ids.end(); ++id)
|
| + if (IsRegistrationRequired(*id))
|
| + return true;
|
| + return false;
|
| +}
|
| +
|
| +bool InvalidationServiceAndroid::IsRegistrationRequired(
|
| + const invalidation::ObjectId& id) {
|
| + // Sync types are registered on the Java side, so only non-Sync objects must
|
| + // be registered with the Android invalidation controller by this class.
|
| + return id.source() != ipc::invalidation::ObjectSource::CHROME_SYNC;
|
| +}
|
| +
|
| +bool RegisterInvalidationController(JNIEnv* env) {
|
| + return RegisterNativesImpl(env);
|
| +}
|
| +
|
| } // namespace invalidation
|
|
|