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

Side by Side Diff: chrome/browser/bookmarks/chrome_bookmark_client.cc

Issue 1203713002: Limit access to ChromeBookmarkClient to bookmarks code (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@cleanup_bookmark_client
Patch Set: Rebase Created 5 years, 6 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 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 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/bookmarks/chrome_bookmark_client.h" 5 #include "chrome/browser/bookmarks/chrome_bookmark_client.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/bind_helpers.h" 8 #include "base/bind_helpers.h"
9 #include "base/logging.h" 9 #include "base/logging.h"
10 #include "base/values.h" 10 #include "base/values.h"
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
56 int64 id = *next_node_id; 56 int64 id = *next_node_id;
57 node->set_id(id); 57 node->set_id(id);
58 *next_node_id = ManagedBookmarksTracker::LoadInitial( 58 *next_node_id = ManagedBookmarksTracker::LoadInitial(
59 node, initial_bookmarks, id + 1); 59 node, initial_bookmarks, id + 1);
60 node->set_visible(!node->empty()); 60 node->set_visible(!node->empty());
61 } 61 }
62 62
63 } // namespace 63 } // namespace
64 64
65 ChromeBookmarkClient::ChromeBookmarkClient(Profile* profile) 65 ChromeBookmarkClient::ChromeBookmarkClient(Profile* profile)
66 : profile_(profile), 66 : profile_(profile) {
67 model_(nullptr),
68 managed_node_(nullptr),
69 supervised_node_(nullptr) {
70 } 67 }
71 68
72 ChromeBookmarkClient::~ChromeBookmarkClient() { 69 ChromeBookmarkClient::~ChromeBookmarkClient() {
73 } 70 }
74 71
75 void ChromeBookmarkClient::Init(BookmarkModel* model) { 72 void ChromeBookmarkClient::Init(BookmarkModel* model) {
76 DCHECK(model); 73 DCHECK(model);
77 DCHECK(!model_);
78 model_ = model;
79 model_->AddObserver(this);
80
81 managed_bookmarks_tracker_.reset(new ManagedBookmarksTracker( 74 managed_bookmarks_tracker_.reset(new ManagedBookmarksTracker(
82 model_, 75 model,
83 profile_->GetPrefs(), 76 profile_->GetPrefs(),
84 false, 77 false,
85 base::Bind(&ChromeBookmarkClient::GetManagedBookmarksDomain, 78 base::Bind(&ChromeBookmarkClient::GetManagedBookmarksDomain,
86 base::Unretained(this)))); 79 base::Unretained(this))));
87 supervised_bookmarks_tracker_.reset(new ManagedBookmarksTracker( 80 supervised_bookmarks_tracker_.reset(new ManagedBookmarksTracker(
88 model_, 81 model,
89 profile_->GetPrefs(), 82 profile_->GetPrefs(),
90 true, 83 true,
91 base::Callback<std::string()>())); 84 base::Callback<std::string()>()));
92 } 85 }
93 86
94 void ChromeBookmarkClient::Shutdown() {
95 if (model_) {
96 model_->RemoveObserver(this);
97 model_ = nullptr;
98 }
99 BookmarkClient::Shutdown();
100 }
101
102 bool ChromeBookmarkClient::PreferTouchIcon() {
103 #if !defined(OS_IOS)
104 return false;
105 #else
106 return true;
107 #endif
108 }
109
110 base::CancelableTaskTracker::TaskId 87 base::CancelableTaskTracker::TaskId
111 ChromeBookmarkClient::GetFaviconImageForPageURL( 88 ChromeBookmarkClient::GetFaviconImageForPageURL(
112 const GURL& page_url, 89 const GURL& page_url,
113 favicon_base::IconType type, 90 favicon_base::IconType type,
114 const favicon_base::FaviconImageCallback& callback, 91 const favicon_base::FaviconImageCallback& callback,
115 base::CancelableTaskTracker* tracker) { 92 base::CancelableTaskTracker* tracker) {
116 favicon::FaviconService* favicon_service = 93 favicon::FaviconService* favicon_service =
117 FaviconServiceFactory::GetForProfile(profile_, 94 FaviconServiceFactory::GetForProfile(profile_,
118 ServiceAccessType::EXPLICIT_ACCESS); 95 ServiceAccessType::EXPLICIT_ACCESS);
119 if (!favicon_service) 96 if (!favicon_service)
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
151 // fetch the URLRow, it is safe to assume that its |typed_count| is 0. 128 // fetch the URLRow, it is safe to assume that its |typed_count| is 0.
152 history::URLRow url; 129 history::URLRow url;
153 if (url_db && url_db->GetRowForURL((*i)->url(), &url)) 130 if (url_db && url_db->GetRowForURL((*i)->url(), &url))
154 typed_count = url.typed_count(); 131 typed_count = url.typed_count();
155 132
156 NodeTypedCountPair pair(*i, typed_count); 133 NodeTypedCountPair pair(*i, typed_count);
157 node_typed_count_pairs->push_back(pair); 134 node_typed_count_pairs->push_back(pair);
158 } 135 }
159 } 136 }
160 137
161 bool ChromeBookmarkClient::IsPermanentNodeVisible(
162 const BookmarkPermanentNode* node) {
163 DCHECK(node->type() == BookmarkNode::BOOKMARK_BAR ||
164 node->type() == BookmarkNode::OTHER_NODE ||
165 node->type() == BookmarkNode::MOBILE ||
166 node == managed_node_ ||
167 node == supervised_node_);
168 if (node == managed_node_ || node == supervised_node_)
169 return false;
170 #if !defined(OS_IOS)
171 return node->type() != BookmarkNode::MOBILE;
172 #else
173 return node->type() == BookmarkNode::MOBILE;
174 #endif
175 }
176
177 void ChromeBookmarkClient::RecordAction(const base::UserMetricsAction& action) { 138 void ChromeBookmarkClient::RecordAction(const base::UserMetricsAction& action) {
178 content::RecordAction(action); 139 content::RecordAction(action);
179 } 140 }
180 141
181 bookmarks::LoadExtraCallback ChromeBookmarkClient::GetLoadExtraNodesCallback() { 142 bookmarks::LoadExtraCallback ChromeBookmarkClient::GetLoadExtraNodesCallback(
182 // Create the managed_node_ and supervised_node_ with a temporary ID of 0 now. 143 scoped_ptr<bookmarks::BookmarkPermanentNode> managed_node,
183 // They will be populated (and assigned proper IDs) in the LoadExtraNodes 144 scoped_ptr<bookmarks::BookmarkPermanentNode> supervised_node,
184 // callback. 145 const ExtraNodeLoadedCallback& callback) {
185 // The ownership of managed_node_ and supervised_node_ is in limbo until
186 // LoadExtraNodes runs, so we leave them in the care of the closure meanwhile.
187 scoped_ptr<BookmarkPermanentNode> managed(new BookmarkPermanentNode(0));
188 managed_node_ = managed.get();
189 scoped_ptr<BookmarkPermanentNode> supervised(new BookmarkPermanentNode(0));
190 supervised_node_ = supervised.get();
191
192 return base::Bind( 146 return base::Bind(
193 &ChromeBookmarkClient::LoadExtraNodes, 147 &ChromeBookmarkClient::LoadExtraNodes,
194 base::Passed(&managed), 148 base::Passed(&managed_node),
195 base::Passed(managed_bookmarks_tracker_->GetInitialManagedBookmarks()), 149 base::Passed(managed_bookmarks_tracker_->GetInitialManagedBookmarks()),
196 base::Passed(&supervised), 150 base::Passed(&supervised_node),
197 base::Passed( 151 base::Passed(supervised_bookmarks_tracker_->GetInitialManagedBookmarks()),
198 supervised_bookmarks_tracker_->GetInitialManagedBookmarks())); 152 callback);
199 } 153 }
200 154
201 bool ChromeBookmarkClient::CanSetPermanentNodeTitle( 155 void ChromeBookmarkClient::DoneLoading(
202 const BookmarkNode* permanent_node) { 156 bookmarks::BookmarkPermanentNode* managed_node,
203 // The |managed_node_| can have its title updated if the user signs in or 157 bookmarks::BookmarkPermanentNode* supervised_node) {
204 // out, since the name of the managed domain can appear in it.
205 // Also, both |managed_node_| and |supervised_node_| can have their title
206 // updated on locale changes (crbug.com/459448).
207 return (!bookmarks::IsDescendantOf(permanent_node, managed_node_) &&
208 !bookmarks::IsDescendantOf(permanent_node, supervised_node_)) ||
209 permanent_node == managed_node_ ||
210 permanent_node == supervised_node_;
211 }
212
213 bool ChromeBookmarkClient::CanSyncNode(const BookmarkNode* node) {
214 return !bookmarks::IsDescendantOf(node, managed_node_) &&
215 !bookmarks::IsDescendantOf(node, supervised_node_);
216 }
217
218 bool ChromeBookmarkClient::CanBeEditedByUser(const BookmarkNode* node) {
219 return !bookmarks::IsDescendantOf(node, managed_node_) &&
220 !bookmarks::IsDescendantOf(node, supervised_node_);
221 }
222
223 void ChromeBookmarkClient::BookmarkModelChanged() {
224 }
225
226 void ChromeBookmarkClient::BookmarkModelLoaded(BookmarkModel* model,
227 bool ids_reassigned) {
228 BaseBookmarkModelObserver::BookmarkModelLoaded(model, ids_reassigned);
229 // Start tracking the managed and supervised bookmarks. This will detect any 158 // Start tracking the managed and supervised bookmarks. This will detect any
230 // changes that may have occurred while the initial managed and supervised 159 // changes that may have occurred while the initial managed and supervised
231 // bookmarks were being loaded on the background. 160 // bookmarks were being loaded on the background.
232 managed_bookmarks_tracker_->Init(managed_node_); 161 managed_bookmarks_tracker_->Init(managed_node);
233 supervised_bookmarks_tracker_->Init(supervised_node_); 162 supervised_bookmarks_tracker_->Init(supervised_node);
234 } 163 }
235 164
236 // static 165 // static
237 bookmarks::BookmarkPermanentNodeList ChromeBookmarkClient::LoadExtraNodes( 166 bookmarks::BookmarkPermanentNodeList ChromeBookmarkClient::LoadExtraNodes(
238 scoped_ptr<BookmarkPermanentNode> managed_node, 167 scoped_ptr<BookmarkPermanentNode> managed_node,
239 scoped_ptr<base::ListValue> initial_managed_bookmarks, 168 scoped_ptr<base::ListValue> initial_managed_bookmarks,
240 scoped_ptr<BookmarkPermanentNode> supervised_node, 169 scoped_ptr<BookmarkPermanentNode> supervised_node,
241 scoped_ptr<base::ListValue> initial_supervised_bookmarks, 170 scoped_ptr<base::ListValue> initial_supervised_bookmarks,
171 const ExtraNodeLoadedCallback& callback,
242 int64* next_node_id) { 172 int64* next_node_id) {
243 LoadInitialContents( 173 LoadInitialContents(
244 managed_node.get(), initial_managed_bookmarks.get(), next_node_id); 174 managed_node.get(), initial_managed_bookmarks.get(), next_node_id);
245 managed_node->SetTitle(l10n_util::GetStringUTF16( 175 managed_node->SetTitle(l10n_util::GetStringUTF16(
246 IDS_BOOKMARK_BAR_MANAGED_FOLDER_DEFAULT_NAME)); 176 IDS_BOOKMARK_BAR_MANAGED_FOLDER_DEFAULT_NAME));
247 177
248 LoadInitialContents( 178 LoadInitialContents(
249 supervised_node.get(), initial_supervised_bookmarks.get(), next_node_id); 179 supervised_node.get(), initial_supervised_bookmarks.get(), next_node_id);
250 supervised_node->SetTitle(l10n_util::GetStringUTF16( 180 supervised_node->SetTitle(l10n_util::GetStringUTF16(
251 IDS_BOOKMARK_BAR_SUPERVISED_FOLDER_DEFAULT_NAME)); 181 IDS_BOOKMARK_BAR_SUPERVISED_FOLDER_DEFAULT_NAME));
252 182
183 if (!callback.is_null())
184 callback.Run(managed_node.get(), supervised_node.get());
185
186 // Ownership of the managed and supervised nodes passed to the caller.
253 bookmarks::BookmarkPermanentNodeList extra_nodes; 187 bookmarks::BookmarkPermanentNodeList extra_nodes;
254 // Ownership of the managed and supervised nodes passed to the caller.
255 extra_nodes.push_back(managed_node.release()); 188 extra_nodes.push_back(managed_node.release());
256 extra_nodes.push_back(supervised_node.release()); 189 extra_nodes.push_back(supervised_node.release());
257 190
258 return extra_nodes.Pass(); 191 return extra_nodes.Pass();
259 } 192 }
260 193
261 std::string ChromeBookmarkClient::GetManagedBookmarksDomain() { 194 std::string ChromeBookmarkClient::GetManagedBookmarksDomain() {
262 policy::ProfilePolicyConnector* connector = 195 policy::ProfilePolicyConnector* connector =
263 policy::ProfilePolicyConnectorFactory::GetForBrowserContext(profile_); 196 policy::ProfilePolicyConnectorFactory::GetForBrowserContext(profile_);
264 if (connector->IsPolicyFromCloudPolicy(policy::key::kManagedBookmarks)) 197 if (connector->IsPolicyFromCloudPolicy(policy::key::kManagedBookmarks))
265 return connector->GetManagementDomain(); 198 return connector->GetManagementDomain();
266 return std::string(); 199 return std::string();
267 } 200 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698