| 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_MANAGED_MODE_MANAGED_USER_SYNC_SERVICE_H_ | 5 #ifndef CHROME_BROWSER_MANAGED_MODE_MANAGED_USER_SYNC_SERVICE_H_ |
| 6 #define CHROME_BROWSER_MANAGED_MODE_MANAGED_USER_SYNC_SERVICE_H_ | 6 #define CHROME_BROWSER_MANAGED_MODE_MANAGED_USER_SYNC_SERVICE_H_ |
| 7 | 7 |
| 8 #include <vector> | 8 #include <vector> |
| 9 | 9 |
| 10 #include "base/callback_forward.h" | 10 #include "base/callback_forward.h" |
| (...skipping 15 matching lines...) Expand all Loading... |
| 26 | 26 |
| 27 class PrefService; | 27 class PrefService; |
| 28 | 28 |
| 29 class ManagedUserSyncService : public BrowserContextKeyedService, | 29 class ManagedUserSyncService : public BrowserContextKeyedService, |
| 30 public syncer::SyncableService { | 30 public syncer::SyncableService { |
| 31 public: | 31 public: |
| 32 // For use with GetAllManagedUsers() below. | 32 // For use with GetAllManagedUsers() below. |
| 33 typedef base::Callback<void(const base::DictionaryValue*)> | 33 typedef base::Callback<void(const base::DictionaryValue*)> |
| 34 ManagedUsersCallback; | 34 ManagedUsersCallback; |
| 35 | 35 |
| 36 // Dictionary keys for entry values of |prefs::kManagedUsers|. |
| 36 static const char kAcknowledged[]; | 37 static const char kAcknowledged[]; |
| 37 static const char kChromeAvatar[]; | 38 static const char kChromeAvatar[]; |
| 38 static const char kChromeOsAvatar[]; | 39 static const char kChromeOsAvatar[]; |
| 40 static const char kMasterKey[]; |
| 39 static const char kName[]; | 41 static const char kName[]; |
| 40 static const char kMasterKey[]; | 42 |
| 43 // Represents a non-existing avatar on Chrome and Chrome OS. |
| 44 static const int kNoAvatar; |
| 41 | 45 |
| 42 virtual ~ManagedUserSyncService(); | 46 virtual ~ManagedUserSyncService(); |
| 43 | 47 |
| 44 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry); | 48 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry); |
| 45 | 49 |
| 46 // Extracts the avatar index from the input |avatar_str| and set | 50 // Extracts the avatar index from the input |avatar_str| and set |
| 47 // |avatar_index| to hold the extracted value. Returns true if the | 51 // |avatar_index| to hold the extracted value. Returns true if the |
| 48 // index was extracted successfully and false otherwise. | 52 // index was extracted successfully and false otherwise. |
| 49 // |avatar_str| should have the format: "chrome-avatar-index:INDEX" | 53 // |avatar_str| should have the format: "chrome-avatar-index:INDEX" |
| 50 // where INDEX is the integer to be extracted. |avatar_str| can be empty | 54 // where INDEX is the integer to be extracted. |avatar_str| can be empty |
| 51 // in case there is no avatar synced for a managed user in which case | 55 // in case there is no avatar synced for a managed user in which case |
| 52 // |avatar_index| is set to -1. | 56 // |avatar_index| is set to -1. |
| 53 static bool GetAvatarIndex(const std::string& avatar_str, int* avatar_index); | 57 static bool GetAvatarIndex(const std::string& avatar_str, int* avatar_index); |
| 54 | 58 |
| 55 // Given an |avatar_index|, it returns a string of the form: | 59 // Given an |avatar_index|, it returns a string of the form: |
| 56 // "chrome-avatar-index:INDEX" where INDEX = |avatar_index|. | 60 // "chrome-avatar-index:INDEX" where INDEX = |avatar_index|. |
| 57 // It is exposed for testing purposes only. | 61 // It is exposed for testing purposes only. |
| 58 static std::string BuildAvatarString(int avatar_index); | 62 static std::string BuildAvatarString(int avatar_index); |
| 59 | 63 |
| 60 void AddObserver(ManagedUserSyncServiceObserver* observer); | 64 void AddObserver(ManagedUserSyncServiceObserver* observer); |
| 61 void RemoveObserver(ManagedUserSyncServiceObserver* observer); | 65 void RemoveObserver(ManagedUserSyncServiceObserver* observer); |
| 62 | 66 |
| 63 void AddManagedUser(const std::string& id, | 67 void AddManagedUser(const std::string& id, |
| 64 const std::string& name, | 68 const std::string& name, |
| 65 const std::string& master_key, | 69 const std::string& master_key, |
| 66 int avatar_index); | 70 int avatar_index); |
| 67 void DeleteManagedUser(const std::string& id); | 71 void DeleteManagedUser(const std::string& id); |
| 68 | 72 |
| 73 // Updates the managed user avatar only if the managed user has |
| 74 // no avatar and |avatar_index| is set to some value other than |
| 75 // |kNoAvatar|. If |avatar_index| equals |kNoAvatar| and the |
| 76 // managed user has an avatar, it will be cleared. However, |
| 77 // to clear an avatar call the convenience method |ClearManagedUserAvatar()|. |
| 78 // Returns true if the avatar value is changed (either updated or cleared) |
| 79 // and false otherwise. |
| 80 bool UpdateManagedUserAvatarIfNeeded(const std::string& id, int avatar_index); |
| 81 void ClearManagedUserAvatar(const std::string& id); |
| 82 |
| 69 // Returns a dictionary containing all managed users managed by this | 83 // Returns a dictionary containing all managed users managed by this |
| 70 // custodian. This method should only be called once this service has started | 84 // custodian. This method should only be called once this service has started |
| 71 // syncing managed users (i.e. has finished its initial merge of local and | 85 // syncing managed users (i.e. has finished its initial merge of local and |
| 72 // server-side data, via MergeDataAndStartSyncing), as the stored data might | 86 // server-side data, via MergeDataAndStartSyncing), as the stored data might |
| 73 // be outdated before that. | 87 // be outdated before that. |
| 74 const base::DictionaryValue* GetManagedUsers(); | 88 const base::DictionaryValue* GetManagedUsers(); |
| 75 | 89 |
| 76 // Calls the passed |callback| with a dictionary containing all managed users | 90 // Calls the passed |callback| with a dictionary containing all managed users |
| 77 // managed by this custodian. | 91 // managed by this custodian. |
| 78 void GetManagedUsersAsync(const ManagedUsersCallback& callback); | 92 void GetManagedUsersAsync(const ManagedUsersCallback& callback); |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 114 scoped_ptr<syncer::SyncErrorFactory> error_handler_; | 128 scoped_ptr<syncer::SyncErrorFactory> error_handler_; |
| 115 | 129 |
| 116 ObserverList<ManagedUserSyncServiceObserver> observers_; | 130 ObserverList<ManagedUserSyncServiceObserver> observers_; |
| 117 | 131 |
| 118 std::vector<ManagedUsersCallback> callbacks_; | 132 std::vector<ManagedUsersCallback> callbacks_; |
| 119 | 133 |
| 120 DISALLOW_COPY_AND_ASSIGN(ManagedUserSyncService); | 134 DISALLOW_COPY_AND_ASSIGN(ManagedUserSyncService); |
| 121 }; | 135 }; |
| 122 | 136 |
| 123 #endif // CHROME_BROWSER_MANAGED_MODE_MANAGED_USER_SYNC_SERVICE_H_ | 137 #endif // CHROME_BROWSER_MANAGED_MODE_MANAGED_USER_SYNC_SERVICE_H_ |
| OLD | NEW |