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

Side by Side Diff: chrome/browser/sync/glue/app_model_associator.cc

Issue 7564037: Apps/Extensions Sync refactoring -- delete most of the old glue, implement new sync API. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Changes for Review Comments Created 9 years, 4 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 | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/sync/glue/app_model_associator.h"
6
7 #include "base/logging.h"
8 #include "base/tracked.h"
9 #include "chrome/browser/extensions/extension_sync_data.h"
10 #include "chrome/browser/sync/api/sync_error.h"
11 #include "chrome/browser/sync/engine/syncapi.h"
12 #include "chrome/browser/sync/glue/extension_sync_traits.h"
13 #include "chrome/browser/sync/glue/extension_sync.h"
14 #include "chrome/browser/sync/profile_sync_service.h"
15 #include "chrome/browser/sync/protocol/extension_specifics.pb.h"
16 #include "content/browser/browser_thread.h"
17
18 namespace browser_sync {
19
20 AppModelAssociator::AppModelAssociator(
21 ExtensionServiceInterface* extension_service,
22 sync_api::UserShare* user_share)
23 : traits_(GetAppSyncTraits()), extension_service_(extension_service),
24 user_share_(user_share) {
25 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
26 DCHECK(extension_service_);
27 DCHECK(user_share_);
28 }
29
30 AppModelAssociator::~AppModelAssociator() {
31 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
32 }
33
34 bool AppModelAssociator::AssociateModels(SyncError* error) {
35 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
36 ExtensionDataMap extension_data_map;
37 if (!SlurpExtensionData(
38 traits_, *extension_service_, user_share_, &extension_data_map)) {
39 error->Reset(FROM_HERE, "Failed to get app data.", model_type());
40 return false;
41 }
42 if (!FlushExtensionData(
43 traits_, extension_data_map, extension_service_, user_share_)) {
44 error->Reset(FROM_HERE, "Failed to flush app data.", model_type());
45 return false;
46 }
47
48 return true;
49 }
50
51 bool AppModelAssociator::DisassociateModels(SyncError* error) {
52 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
53 // Nothing to do.
54 return true;
55 }
56
57 bool AppModelAssociator::SyncModelHasUserCreatedNodes(bool* has_nodes) {
58 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
59 return RootNodeHasChildren(traits_.root_node_tag, user_share_, has_nodes);
60 }
61
62 void AppModelAssociator::AbortAssociation() {
63 // No implementation needed, this associator runs on the main
64 // thread.
65 }
66
67 bool AppModelAssociator::CryptoReadyIfNecessary() {
68 // We only access the cryptographer while holding a transaction.
69 sync_api::ReadTransaction trans(FROM_HERE, user_share_);
70 const syncable::ModelTypeSet& encrypted_types =
71 sync_api::GetEncryptedTypes(&trans);
72 return encrypted_types.count(traits_.model_type) == 0 ||
73 trans.GetCryptographer()->is_ready();
74 }
75
76 } // namespace browser_sync
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698