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

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

Issue 353493002: Apps&Extensions for supervised users: Add Extension::WAS_INSTALLED_BY_CUSTODIAN flag and proto entry (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: rebase Created 6 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 | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/extension_sync_data.h" 5 #include "chrome/browser/extensions/extension_sync_data.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "chrome/browser/extensions/app_sync_data.h" 8 #include "chrome/browser/extensions/app_sync_data.h"
9 #include "chrome/browser/extensions/extension_service.h" 9 #include "chrome/browser/extensions/extension_service.h"
10 #include "chrome/common/extensions/manifest_url_handler.h" 10 #include "chrome/common/extensions/manifest_url_handler.h"
11 #include "extensions/common/extension.h" 11 #include "extensions/common/extension.h"
12 #include "sync/api/sync_data.h" 12 #include "sync/api/sync_data.h"
13 #include "sync/protocol/extension_specifics.pb.h" 13 #include "sync/protocol/extension_specifics.pb.h"
14 #include "sync/protocol/sync.pb.h" 14 #include "sync/protocol/sync.pb.h"
15 15
16 namespace extensions { 16 namespace extensions {
17 17
18 ExtensionSyncData::ExtensionSyncData() 18 ExtensionSyncData::ExtensionSyncData()
19 : uninstalled_(false), 19 : uninstalled_(false),
20 enabled_(false), 20 enabled_(false),
21 incognito_enabled_(false), 21 incognito_enabled_(false),
22 remote_install_(false) { 22 remote_install_(false),
23 installed_by_custodian_(false) {
23 } 24 }
24 25
25 ExtensionSyncData::ExtensionSyncData(const syncer::SyncData& sync_data) 26 ExtensionSyncData::ExtensionSyncData(const syncer::SyncData& sync_data)
26 : uninstalled_(false), 27 : uninstalled_(false),
27 enabled_(false), 28 enabled_(false),
28 incognito_enabled_(false), 29 incognito_enabled_(false),
29 remote_install_(false) { 30 remote_install_(false),
31 installed_by_custodian_(false) {
30 PopulateFromSyncData(sync_data); 32 PopulateFromSyncData(sync_data);
31 } 33 }
32 34
33 ExtensionSyncData::ExtensionSyncData(const syncer::SyncChange& sync_change) 35 ExtensionSyncData::ExtensionSyncData(const syncer::SyncChange& sync_change)
34 : uninstalled_(sync_change.change_type() == 36 : uninstalled_(sync_change.change_type() ==
35 syncer::SyncChange::ACTION_DELETE), 37 syncer::SyncChange::ACTION_DELETE),
36 enabled_(false), 38 enabled_(false),
37 incognito_enabled_(false), 39 incognito_enabled_(false),
38 remote_install_(false) { 40 remote_install_(false),
41 installed_by_custodian_(false) {
39 PopulateFromSyncData(sync_change.sync_data()); 42 PopulateFromSyncData(sync_change.sync_data());
40 } 43 }
41 44
42 ExtensionSyncData::ExtensionSyncData(const Extension& extension, 45 ExtensionSyncData::ExtensionSyncData(const Extension& extension,
43 bool enabled, 46 bool enabled,
44 bool incognito_enabled, 47 bool incognito_enabled,
45 bool remote_install) 48 bool remote_install)
46 : id_(extension.id()), 49 : id_(extension.id()),
47 uninstalled_(false), 50 uninstalled_(false),
48 enabled_(enabled), 51 enabled_(enabled),
49 incognito_enabled_(incognito_enabled), 52 incognito_enabled_(incognito_enabled),
50 remote_install_(remote_install), 53 remote_install_(remote_install),
54 installed_by_custodian_(extension.was_installed_by_custodian()),
51 version_(extension.from_bookmark() ? base::Version("0") 55 version_(extension.from_bookmark() ? base::Version("0")
52 : *extension.version()), 56 : *extension.version()),
53 update_url_(ManifestURL::GetUpdateURL(&extension)), 57 update_url_(ManifestURL::GetUpdateURL(&extension)),
54 name_(extension.non_localized_name()) { 58 name_(extension.non_localized_name()) {
55 } 59 }
56 60
57 ExtensionSyncData::~ExtensionSyncData() {} 61 ExtensionSyncData::~ExtensionSyncData() {}
58 62
59 syncer::SyncData ExtensionSyncData::GetSyncData() const { 63 syncer::SyncData ExtensionSyncData::GetSyncData() const {
60 sync_pb::EntitySpecifics specifics; 64 sync_pb::EntitySpecifics specifics;
61 PopulateExtensionSpecifics(specifics.mutable_extension()); 65 PopulateExtensionSpecifics(specifics.mutable_extension());
62 66
63 return syncer::SyncData::CreateLocalData(id_, name_, specifics); 67 return syncer::SyncData::CreateLocalData(id_, name_, specifics);
64 } 68 }
65 69
66 syncer::SyncChange ExtensionSyncData::GetSyncChange( 70 syncer::SyncChange ExtensionSyncData::GetSyncChange(
67 syncer::SyncChange::SyncChangeType change_type) const { 71 syncer::SyncChange::SyncChangeType change_type) const {
68 return syncer::SyncChange(FROM_HERE, change_type, GetSyncData()); 72 return syncer::SyncChange(FROM_HERE, change_type, GetSyncData());
69 } 73 }
70 74
71 void ExtensionSyncData::PopulateExtensionSpecifics( 75 void ExtensionSyncData::PopulateExtensionSpecifics(
72 sync_pb::ExtensionSpecifics* specifics) const { 76 sync_pb::ExtensionSpecifics* specifics) const {
73 DCHECK(Extension::IdIsValid(id_)); 77 DCHECK(Extension::IdIsValid(id_));
74 specifics->set_id(id_); 78 specifics->set_id(id_);
75 specifics->set_update_url(update_url_.spec()); 79 specifics->set_update_url(update_url_.spec());
76 specifics->set_version(version_.GetString()); 80 specifics->set_version(version_.GetString());
77 specifics->set_enabled(enabled_); 81 specifics->set_enabled(enabled_);
78 specifics->set_incognito_enabled(incognito_enabled_); 82 specifics->set_incognito_enabled(incognito_enabled_);
79 specifics->set_remote_install(remote_install_); 83 specifics->set_remote_install(remote_install_);
84 specifics->set_installed_by_custodian(installed_by_custodian_);
80 specifics->set_name(name_); 85 specifics->set_name(name_);
81 } 86 }
82 87
83 void ExtensionSyncData::PopulateFromExtensionSpecifics( 88 void ExtensionSyncData::PopulateFromExtensionSpecifics(
84 const sync_pb::ExtensionSpecifics& specifics) { 89 const sync_pb::ExtensionSpecifics& specifics) {
85 if (!Extension::IdIsValid(specifics.id())) { 90 if (!Extension::IdIsValid(specifics.id())) {
86 LOG(FATAL) << "Attempt to sync bad ExtensionSpecifics."; 91 LOG(FATAL) << "Attempt to sync bad ExtensionSpecifics.";
87 } 92 }
88 93
89 Version specifics_version(specifics.version()); 94 Version specifics_version(specifics.version());
90 if (!specifics_version.IsValid()) 95 if (!specifics_version.IsValid())
91 LOG(FATAL) << "Attempt to sync bad ExtensionSpecifics."; 96 LOG(FATAL) << "Attempt to sync bad ExtensionSpecifics.";
92 97
93 // The update URL must be either empty or valid. 98 // The update URL must be either empty or valid.
94 GURL specifics_update_url(specifics.update_url()); 99 GURL specifics_update_url(specifics.update_url());
95 if (!specifics_update_url.is_empty() && !specifics_update_url.is_valid()) { 100 if (!specifics_update_url.is_empty() && !specifics_update_url.is_valid()) {
96 LOG(FATAL) << "Attempt to sync bad ExtensionSpecifics."; 101 LOG(FATAL) << "Attempt to sync bad ExtensionSpecifics.";
97 } 102 }
98 103
99 id_ = specifics.id(); 104 id_ = specifics.id();
100 update_url_ = specifics_update_url; 105 update_url_ = specifics_update_url;
101 version_ = specifics_version; 106 version_ = specifics_version;
102 enabled_ = specifics.enabled(); 107 enabled_ = specifics.enabled();
103 incognito_enabled_ = specifics.incognito_enabled(); 108 incognito_enabled_ = specifics.incognito_enabled();
104 remote_install_ = specifics.remote_install(); 109 remote_install_ = specifics.remote_install();
110 installed_by_custodian_ = specifics.installed_by_custodian();
105 name_ = specifics.name(); 111 name_ = specifics.name();
106 } 112 }
107 113
108 void ExtensionSyncData::set_uninstalled(bool uninstalled) { 114 void ExtensionSyncData::set_uninstalled(bool uninstalled) {
109 uninstalled_ = uninstalled; 115 uninstalled_ = uninstalled;
110 } 116 }
111 117
112 void ExtensionSyncData::PopulateFromSyncData( 118 void ExtensionSyncData::PopulateFromSyncData(
113 const syncer::SyncData& sync_data) { 119 const syncer::SyncData& sync_data) {
114 const sync_pb::EntitySpecifics& entity_specifics = sync_data.GetSpecifics(); 120 const sync_pb::EntitySpecifics& entity_specifics = sync_data.GetSpecifics();
115 121
116 if (entity_specifics.has_extension()) { 122 if (entity_specifics.has_extension()) {
117 PopulateFromExtensionSpecifics(entity_specifics.extension()); 123 PopulateFromExtensionSpecifics(entity_specifics.extension());
118 } else { 124 } else {
119 LOG(FATAL) << "Attempt to sync bad EntitySpecifics."; 125 LOG(FATAL) << "Attempt to sync bad EntitySpecifics.";
120 } 126 }
121 } 127 }
122 128
123 } // namespace extensions 129 } // namespace extensions
OLDNEW
« no previous file with comments | « chrome/browser/extensions/extension_sync_data.h ('k') | chrome/browser/extensions/extension_sync_service.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698