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

Side by Side Diff: chrome/browser/extensions/sync_bundle.cc

Issue 1240573012: Extension syncing: Introduce a NeedsSync pref (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@ext_sync_uninstall
Patch Set: ...and browser_tests Created 5 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 unified diff | Download patch
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/sync_bundle.h" 5 #include "chrome/browser/extensions/sync_bundle.h"
6 6
7 #include "base/location.h" 7 #include "base/location.h"
8 #include "chrome/browser/extensions/extension_sync_data.h" 8 #include "chrome/browser/extensions/extension_sync_data.h"
9 #include "chrome/browser/extensions/extension_sync_service.h" 9 #include "chrome/browser/extensions/extension_sync_service.h"
10 #include "chrome/browser/extensions/extension_util.h" 10 #include "chrome/browser/extensions/extension_util.h"
11 #include "chrome/browser/profiles/profile.h" 11 #include "chrome/browser/profiles/profile.h"
12 #include "extensions/common/extension.h" 12 #include "extensions/common/extension.h"
13 13
14 namespace extensions { 14 namespace extensions {
15 15
16 SyncBundle::SyncBundle(ExtensionSyncService* sync_service) 16 SyncBundle::SyncBundle() {}
17 : sync_service_(sync_service) {}
18
19 SyncBundle::~SyncBundle() {} 17 SyncBundle::~SyncBundle() {}
20 18
21 void SyncBundle::MergeDataAndStartSyncing( 19 void SyncBundle::Init(scoped_ptr<syncer::SyncChangeProcessor> sync_processor) {
22 const syncer::SyncDataList& initial_sync_data,
23 scoped_ptr<syncer::SyncChangeProcessor> sync_processor) {
24 sync_processor_.reset(sync_processor.release()); 20 sync_processor_.reset(sync_processor.release());
25
26 for (const syncer::SyncData& sync_data : initial_sync_data) {
27 scoped_ptr<ExtensionSyncData> extension_sync_data(
28 ExtensionSyncData::CreateFromSyncData(sync_data));
29 if (extension_sync_data.get()) {
30 AddSyncedExtension(extension_sync_data->id());
31 sync_service_->ApplySyncData(*extension_sync_data);
32 }
33 }
34 } 21 }
35 22
36 void SyncBundle::Reset() { 23 void SyncBundle::Reset() {
37 sync_processor_.reset(); 24 sync_processor_.reset();
38 synced_extensions_.clear(); 25 synced_extensions_.clear();
39 pending_sync_data_.clear(); 26 pending_sync_data_.clear();
40 } 27 }
41 28
42 bool SyncBundle::IsSyncing() const { 29 bool SyncBundle::IsSyncing() const {
43 return sync_processor_ != nullptr; 30 return sync_processor_ != nullptr;
44 } 31 }
45 32
46 bool SyncBundle::HasExtensionId(const std::string& id) const {
47 return synced_extensions_.find(id) != synced_extensions_.end();
48 }
49
50 bool SyncBundle::ShouldIncludeInLocalSyncDataList(
51 const Extension& extension) const {
52 // If there is pending data for this extension, then this version is out of
53 // date. We'll sync back the version we got from sync.
54 return IsSyncing() && !HasPendingExtensionId(extension.id());
55 }
56
57 void SyncBundle::PushSyncDataList( 33 void SyncBundle::PushSyncDataList(
58 const syncer::SyncDataList& sync_data_list) { 34 const syncer::SyncDataList& sync_data_list) {
59 syncer::SyncChangeList sync_change_list; 35 syncer::SyncChangeList sync_change_list;
60 for (const syncer::SyncData& sync_data : sync_data_list) { 36 for (const syncer::SyncData& sync_data : sync_data_list) {
61 const syncer::SyncDataLocal sync_data_local(sync_data); 37 const syncer::SyncDataLocal sync_data_local(sync_data);
62 const std::string& extension_id = sync_data_local.GetTag(); 38 const std::string& extension_id = sync_data_local.GetTag();
63 39
64 sync_change_list.push_back(CreateSyncChange(extension_id, sync_data)); 40 sync_change_list.push_back(CreateSyncChange(extension_id, sync_data));
65 41
66 AddSyncedExtension(extension_id); 42 AddSyncedExtension(extension_id);
67 } 43 }
68 44
69 PushSyncChanges(sync_change_list); 45 PushSyncChanges(sync_change_list);
70 } 46 }
71 47
72 void SyncBundle::PushSyncDeletion(const std::string& extension_id, 48 void SyncBundle::PushSyncDeletion(const std::string& extension_id,
73 const syncer::SyncData& sync_data) { 49 const syncer::SyncData& sync_data) {
50 if (!HasSyncedExtension(extension_id))
51 return;
52
74 RemoveSyncedExtension(extension_id); 53 RemoveSyncedExtension(extension_id);
75 PushSyncChanges(syncer::SyncChangeList(1, 54 PushSyncChanges(syncer::SyncChangeList(1,
76 syncer::SyncChange(FROM_HERE, 55 syncer::SyncChange(FROM_HERE,
77 syncer::SyncChange::ACTION_DELETE, 56 syncer::SyncChange::ACTION_DELETE,
78 sync_data))); 57 sync_data)));
79 } 58 }
80 59
81 void SyncBundle::PushSyncAddOrUpdate(const Extension& extension) { 60 void SyncBundle::PushSyncAddOrUpdate(const std::string& extension_id,
82 syncer::SyncChangeList sync_change_list( 61 const syncer::SyncData& sync_data) {
83 1, 62 AddSyncedExtension(extension_id);
84 CreateSyncChange(extension.id(), 63 PushSyncChanges(syncer::SyncChangeList(
85 sync_service_->CreateSyncData(extension).GetSyncData())); 64 1, CreateSyncChange(extension_id, sync_data)));
86 PushSyncChanges(sync_change_list); 65 // Now sync and local state agree. If we had any pending change from sync,
87 MarkPendingExtensionSynced(extension.id()); 66 // clear it now.
67 pending_sync_data_.erase(extension_id);
88 } 68 }
89 69
90 void SyncBundle::ApplySyncChange(const syncer::SyncChange& sync_change) { 70 void SyncBundle::ApplySyncData(const ExtensionSyncData& extension_sync_data) {
91 scoped_ptr<ExtensionSyncData> extension_sync_data( 71 if (extension_sync_data.uninstalled())
92 ExtensionSyncData::CreateFromSyncChange(sync_change)); 72 RemoveSyncedExtension(extension_sync_data.id());
93 if (!extension_sync_data.get())
94 return; // TODO(treib,kalman): Warning message?
95
96 if (extension_sync_data->uninstalled())
97 RemoveSyncedExtension(extension_sync_data->id());
98 else 73 else
99 AddSyncedExtension(extension_sync_data->id()); 74 AddSyncedExtension(extension_sync_data.id());
100 sync_service_->ApplySyncData(*extension_sync_data);
101 } 75 }
102 76
103 bool SyncBundle::HasPendingExtensionId(const std::string& id) const { 77 bool SyncBundle::HasPendingExtensionId(const std::string& id) const {
104 return pending_sync_data_.find(id) != pending_sync_data_.end(); 78 return pending_sync_data_.find(id) != pending_sync_data_.end();
105 } 79 }
106 80
107 void SyncBundle::AddPendingExtension( 81 void SyncBundle::AddPendingExtension(
108 const std::string& id, 82 const std::string& id,
109 const ExtensionSyncData& extension_sync_data) { 83 const ExtensionSyncData& extension_sync_data) {
110 pending_sync_data_.insert(std::make_pair(id, extension_sync_data)); 84 pending_sync_data_.insert(std::make_pair(id, extension_sync_data));
111 } 85 }
112 86
113 std::vector<ExtensionSyncData> SyncBundle::GetPendingData() const { 87 std::vector<ExtensionSyncData> SyncBundle::GetPendingData() const {
114 std::vector<ExtensionSyncData> pending_extensions; 88 std::vector<ExtensionSyncData> pending_extensions;
115 for (const auto& data : pending_sync_data_) 89 for (const auto& data : pending_sync_data_)
116 pending_extensions.push_back(data.second); 90 pending_extensions.push_back(data.second);
117 91
118 return pending_extensions; 92 return pending_extensions;
119 } 93 }
120 94
121 syncer::SyncChange SyncBundle::CreateSyncChange( 95 syncer::SyncChange SyncBundle::CreateSyncChange(
122 const std::string& extension_id, 96 const std::string& extension_id,
123 const syncer::SyncData& sync_data) const { 97 const syncer::SyncData& sync_data) const {
124 return syncer::SyncChange( 98 return syncer::SyncChange(
125 FROM_HERE, 99 FROM_HERE,
126 HasExtensionId(extension_id) ? syncer::SyncChange::ACTION_UPDATE 100 HasSyncedExtension(extension_id) ? syncer::SyncChange::ACTION_UPDATE
127 : syncer::SyncChange::ACTION_ADD, 101 : syncer::SyncChange::ACTION_ADD,
128 sync_data); 102 sync_data);
129 } 103 }
130 104
131 void SyncBundle::PushSyncChanges( 105 void SyncBundle::PushSyncChanges(
132 const syncer::SyncChangeList& sync_change_list) { 106 const syncer::SyncChangeList& sync_change_list) {
133 sync_processor_->ProcessSyncChanges(FROM_HERE, sync_change_list); 107 sync_processor_->ProcessSyncChanges(FROM_HERE, sync_change_list);
134 } 108 }
135 109
136 void SyncBundle::AddSyncedExtension(const std::string& id) { 110 void SyncBundle::AddSyncedExtension(const std::string& id) {
137 synced_extensions_.insert(id); 111 synced_extensions_.insert(id);
138 } 112 }
139 113
140 void SyncBundle::RemoveSyncedExtension(const std::string& id) { 114 void SyncBundle::RemoveSyncedExtension(const std::string& id) {
141 synced_extensions_.erase(id); 115 synced_extensions_.erase(id);
142 } 116 }
143 117
144 void SyncBundle::MarkPendingExtensionSynced(const std::string& id) { 118 bool SyncBundle::HasSyncedExtension(const std::string& id) const {
145 pending_sync_data_.erase(id); 119 return synced_extensions_.find(id) != synced_extensions_.end();
146 AddSyncedExtension(id);
147 } 120 }
148 121
149 } // namespace extensions 122 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698