| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #ifndef CHROME_BROWSER_SYNC_PROFILE_SYNC_SERVICE_ANDROID_H_ | 5 #ifndef CHROME_BROWSER_SYNC_PROFILE_SYNC_SERVICE_ANDROID_H_ |
| 6 #define CHROME_BROWSER_SYNC_PROFILE_SYNC_SERVICE_ANDROID_H_ | 6 #define CHROME_BROWSER_SYNC_PROFILE_SYNC_SERVICE_ANDROID_H_ |
| 7 | 7 |
| 8 #include <jni.h> | 8 #include <jni.h> |
| 9 #include <map> | 9 #include <map> |
| 10 | 10 |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 // ProfileSyncService. | 26 // ProfileSyncService. |
| 27 // This class should only be accessed from the UI thread. | 27 // This class should only be accessed from the UI thread. |
| 28 class ProfileSyncServiceAndroid : public ProfileSyncServiceObserver { | 28 class ProfileSyncServiceAndroid : public ProfileSyncServiceObserver { |
| 29 public: | 29 public: |
| 30 | 30 |
| 31 ProfileSyncServiceAndroid(JNIEnv* env, jobject obj); | 31 ProfileSyncServiceAndroid(JNIEnv* env, jobject obj); |
| 32 | 32 |
| 33 // This method should be called once right after contructing the object. | 33 // This method should be called once right after contructing the object. |
| 34 void Init(); | 34 void Init(); |
| 35 | 35 |
| 36 // Called from Java when we need to nudge native syncer. The |objectId|, | 36 // Called from Java when we need to nudge native syncer. The |objectSource|, |
| 37 // |version| and |payload| values should come from an invalidation. | 37 // |objectId|, |version| and |payload| values should come from an |
| 38 // invalidation. |
| 38 void NudgeSyncer(JNIEnv* env, | 39 void NudgeSyncer(JNIEnv* env, |
| 39 jobject obj, | 40 jobject obj, |
| 41 jint objectSource, |
| 40 jstring objectId, | 42 jstring objectId, |
| 41 jlong version, | 43 jlong version, |
| 42 jstring payload); | 44 jstring payload); |
| 43 | 45 |
| 44 // Called from Java when we need to nudge native syncer but have lost state on | 46 // Called from Java when we need to nudge native syncer but have lost state on |
| 45 // which types have changed. | 47 // which types have changed. |
| 46 void NudgeSyncerForAllTypes(JNIEnv* env, jobject obj); | 48 void NudgeSyncerForAllTypes(JNIEnv* env, jobject obj); |
| 47 | 49 |
| 48 void TokenAvailable(JNIEnv*, jobject, jstring username, jstring auth_token); | 50 void TokenAvailable(JNIEnv*, jobject, jstring username, jstring auth_token); |
| 49 | 51 |
| (...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 199 static bool Register(JNIEnv* env); | 201 static bool Register(JNIEnv* env); |
| 200 | 202 |
| 201 private: | 203 private: |
| 202 typedef std::map<invalidation::ObjectId, | 204 typedef std::map<invalidation::ObjectId, |
| 203 int64, | 205 int64, |
| 204 syncer::ObjectIdLessThan> ObjectIdVersionMap; | 206 syncer::ObjectIdLessThan> ObjectIdVersionMap; |
| 205 | 207 |
| 206 virtual ~ProfileSyncServiceAndroid(); | 208 virtual ~ProfileSyncServiceAndroid(); |
| 207 // Remove observers to profile sync service. | 209 // Remove observers to profile sync service. |
| 208 void RemoveObserver(); | 210 void RemoveObserver(); |
| 209 // Called from Java when we need to nudge native syncer. The |objectId|, | 211 // Called from Java when we need to nudge native syncer. The |object_source|, |
| 210 // |version| and |payload| values should come from an invalidation. | 212 // |objectId|, |version| and |payload| values should come from an |
| 211 void SendNudgeNotification(const std::string& str_object_id, | 213 // invalidation. |
| 214 void SendNudgeNotification(int object_source, |
| 215 const std::string& str_object_id, |
| 212 int64 version, | 216 int64 version, |
| 213 const std::string& payload); | 217 const std::string& payload); |
| 214 | 218 |
| 215 Profile* profile_; | 219 Profile* profile_; |
| 216 ProfileSyncService* sync_service_; | 220 ProfileSyncService* sync_service_; |
| 217 // The class that handles getting, setting, and persisting sync | 221 // The class that handles getting, setting, and persisting sync |
| 218 // preferences. | 222 // preferences. |
| 219 scoped_ptr<browser_sync::SyncPrefs> sync_prefs_; | 223 scoped_ptr<browser_sync::SyncPrefs> sync_prefs_; |
| 220 | 224 |
| 221 // Java-side ProfileSyncService object. | 225 // Java-side ProfileSyncService object. |
| 222 JavaObjectWeakGlobalRef weak_java_profile_sync_service_; | 226 JavaObjectWeakGlobalRef weak_java_profile_sync_service_; |
| 223 | 227 |
| 224 // The invalidation API spec allows for the possibility of redundant | 228 // The invalidation API spec allows for the possibility of redundant |
| 225 // invalidations, so keep track of the max versions and drop | 229 // invalidations, so keep track of the max versions and drop |
| 226 // invalidations with old versions. | 230 // invalidations with old versions. |
| 227 ObjectIdVersionMap max_invalidation_versions_; | 231 ObjectIdVersionMap max_invalidation_versions_; |
| 228 | 232 |
| 229 DISALLOW_COPY_AND_ASSIGN(ProfileSyncServiceAndroid); | 233 DISALLOW_COPY_AND_ASSIGN(ProfileSyncServiceAndroid); |
| 230 }; | 234 }; |
| 231 | 235 |
| 232 #endif // CHROME_BROWSER_SYNC_PROFILE_SYNC_SERVICE_ANDROID_H_ | 236 #endif // CHROME_BROWSER_SYNC_PROFILE_SYNC_SERVICE_ANDROID_H_ |
| OLD | NEW |