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

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: (b); hackfix sync_integration_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::StartSyncing(
22 const syncer::SyncDataList& initial_sync_data,
23 scoped_ptr<syncer::SyncChangeProcessor> sync_processor) { 20 scoped_ptr<syncer::SyncChangeProcessor> sync_processor) {
24 sync_processor_.reset(sync_processor.release()); 21 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 } 22 }
35 23
36 void SyncBundle::Reset() { 24 void SyncBundle::Reset() {
37 sync_processor_.reset(); 25 sync_processor_.reset();
38 synced_extensions_.clear(); 26 synced_extensions_.clear();
39 pending_sync_data_.clear(); 27 pending_sync_data_.clear();
40 } 28 }
41 29
42 bool SyncBundle::IsSyncing() const { 30 bool SyncBundle::IsSyncing() const {
43 return sync_processor_ != nullptr; 31 return sync_processor_ != nullptr;
44 } 32 }
45 33
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( 34 void SyncBundle::PushSyncDataList(
58 const syncer::SyncDataList& sync_data_list) { 35 const syncer::SyncDataList& sync_data_list) {
59 syncer::SyncChangeList sync_change_list; 36 syncer::SyncChangeList sync_change_list;
60 for (const syncer::SyncData& sync_data : sync_data_list) { 37 for (const syncer::SyncData& sync_data : sync_data_list) {
61 const syncer::SyncDataLocal sync_data_local(sync_data); 38 const syncer::SyncDataLocal sync_data_local(sync_data);
62 const std::string& extension_id = sync_data_local.GetTag(); 39 const std::string& extension_id = sync_data_local.GetTag();
63 40
64 sync_change_list.push_back(CreateSyncChange(extension_id, sync_data)); 41 sync_change_list.push_back(CreateSyncChange(extension_id, sync_data));
65 42
66 AddSyncedExtension(extension_id); 43 AddSyncedExtension(extension_id);
67 } 44 }
68 45
69 PushSyncChanges(sync_change_list); 46 PushSyncChanges(sync_change_list);
70 } 47 }
71 48
72 void SyncBundle::PushSyncDeletion(const std::string& extension_id, 49 void SyncBundle::PushSyncDeletion(const std::string& extension_id,
73 const syncer::SyncData& sync_data) { 50 const syncer::SyncData& sync_data) {
51 if (!HasSyncedExtension(extension_id))
52 return;
53
74 RemoveSyncedExtension(extension_id); 54 RemoveSyncedExtension(extension_id);
75 PushSyncChanges(syncer::SyncChangeList(1, 55 PushSyncChanges(syncer::SyncChangeList(1,
76 syncer::SyncChange(FROM_HERE, 56 syncer::SyncChange(FROM_HERE,
77 syncer::SyncChange::ACTION_DELETE, 57 syncer::SyncChange::ACTION_DELETE,
78 sync_data))); 58 sync_data)));
79 } 59 }
80 60
81 void SyncBundle::PushSyncAddOrUpdate(const Extension& extension) { 61 void SyncBundle::PushSyncAddOrUpdate(const std::string& extension_id,
82 syncer::SyncChangeList sync_change_list( 62 const syncer::SyncData& sync_data) {
83 1, 63 PushSyncChanges(syncer::SyncChangeList(
84 CreateSyncChange(extension.id(), 64 1, CreateSyncChange(extension_id, sync_data)));
85 sync_service_->CreateSyncData(extension).GetSyncData())); 65 AddSyncedExtension(extension_id);
86 PushSyncChanges(sync_change_list); 66 // Now sync and local state agree. If we had any pending change from sync,
87 MarkPendingExtensionSynced(extension.id()); 67 // clear it now.
68 pending_sync_data_.erase(extension_id);
88 } 69 }
89 70
90 void SyncBundle::ApplySyncChange(const syncer::SyncChange& sync_change) { 71 void SyncBundle::ApplySyncData(const ExtensionSyncData& extension_sync_data) {
91 scoped_ptr<ExtensionSyncData> extension_sync_data( 72 if (extension_sync_data.uninstalled())
92 ExtensionSyncData::CreateFromSyncChange(sync_change)); 73 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 74 else
99 AddSyncedExtension(extension_sync_data->id()); 75 AddSyncedExtension(extension_sync_data.id());
100 sync_service_->ApplySyncData(*extension_sync_data);
101 } 76 }
102 77
103 bool SyncBundle::HasPendingExtensionId(const std::string& id) const { 78 bool SyncBundle::HasPendingExtensionId(const std::string& id) const {
104 return pending_sync_data_.find(id) != pending_sync_data_.end(); 79 return pending_sync_data_.find(id) != pending_sync_data_.end();
105 } 80 }
106 81
107 void SyncBundle::AddPendingExtension( 82 void SyncBundle::AddPendingExtension(
108 const std::string& id, 83 const std::string& id,
109 const ExtensionSyncData& extension_sync_data) { 84 const ExtensionSyncData& extension_sync_data) {
110 pending_sync_data_.insert(std::make_pair(id, extension_sync_data)); 85 pending_sync_data_.insert(std::make_pair(id, extension_sync_data));
111 } 86 }
112 87
113 std::vector<ExtensionSyncData> SyncBundle::GetPendingData() const { 88 std::vector<ExtensionSyncData> SyncBundle::GetPendingData() const {
114 std::vector<ExtensionSyncData> pending_extensions; 89 std::vector<ExtensionSyncData> pending_extensions;
115 for (const auto& data : pending_sync_data_) 90 for (const auto& data : pending_sync_data_)
116 pending_extensions.push_back(data.second); 91 pending_extensions.push_back(data.second);
117 92
118 return pending_extensions; 93 return pending_extensions;
119 } 94 }
120 95
121 syncer::SyncChange SyncBundle::CreateSyncChange( 96 syncer::SyncChange SyncBundle::CreateSyncChange(
122 const std::string& extension_id, 97 const std::string& extension_id,
123 const syncer::SyncData& sync_data) const { 98 const syncer::SyncData& sync_data) const {
124 return syncer::SyncChange( 99 return syncer::SyncChange(
125 FROM_HERE, 100 FROM_HERE,
126 HasExtensionId(extension_id) ? syncer::SyncChange::ACTION_UPDATE 101 HasSyncedExtension(extension_id) ? syncer::SyncChange::ACTION_UPDATE
127 : syncer::SyncChange::ACTION_ADD, 102 : syncer::SyncChange::ACTION_ADD,
128 sync_data); 103 sync_data);
129 } 104 }
130 105
131 void SyncBundle::PushSyncChanges( 106 void SyncBundle::PushSyncChanges(
132 const syncer::SyncChangeList& sync_change_list) { 107 const syncer::SyncChangeList& sync_change_list) {
133 sync_processor_->ProcessSyncChanges(FROM_HERE, sync_change_list); 108 sync_processor_->ProcessSyncChanges(FROM_HERE, sync_change_list);
134 } 109 }
135 110
136 void SyncBundle::AddSyncedExtension(const std::string& id) { 111 void SyncBundle::AddSyncedExtension(const std::string& id) {
137 synced_extensions_.insert(id); 112 synced_extensions_.insert(id);
138 } 113 }
139 114
140 void SyncBundle::RemoveSyncedExtension(const std::string& id) { 115 void SyncBundle::RemoveSyncedExtension(const std::string& id) {
141 synced_extensions_.erase(id); 116 synced_extensions_.erase(id);
142 } 117 }
143 118
144 void SyncBundle::MarkPendingExtensionSynced(const std::string& id) { 119 bool SyncBundle::HasSyncedExtension(const std::string& id) const {
145 pending_sync_data_.erase(id); 120 return synced_extensions_.find(id) != synced_extensions_.end();
146 AddSyncedExtension(id);
147 } 121 }
148 122
149 } // namespace extensions 123 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698