OLD | NEW |
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/supervised_user/supervised_user_whitelist_service.h" | 5 #include "chrome/browser/supervised_user/supervised_user_whitelist_service.h" |
6 | 6 |
7 #include <string> | 7 #include <string> |
8 | 8 |
9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
10 #include "base/files/file_path.h" | 10 #include "base/files/file_path.h" |
(...skipping 93 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
104 | 104 |
105 const bool result = whitelists.insert(std::make_pair(id, name)).second; | 105 const bool result = whitelists.insert(std::make_pair(id, name)).second; |
106 DCHECK(result); | 106 DCHECK(result); |
107 } | 107 } |
108 | 108 |
109 return whitelists; | 109 return whitelists; |
110 } | 110 } |
111 | 111 |
112 void SupervisedUserWhitelistService::LoadWhitelistForTesting( | 112 void SupervisedUserWhitelistService::LoadWhitelistForTesting( |
113 const std::string& id, | 113 const std::string& id, |
| 114 const base::string16& title, |
114 const base::FilePath& path) { | 115 const base::FilePath& path) { |
115 bool result = registered_whitelists_.insert(id).second; | 116 bool result = registered_whitelists_.insert(id).second; |
116 DCHECK(result); | 117 DCHECK(result); |
117 OnWhitelistReady(id, path); | 118 OnWhitelistReady(id, title, path); |
118 } | 119 } |
119 | 120 |
120 void SupervisedUserWhitelistService::UnloadWhitelist(const std::string& id) { | 121 void SupervisedUserWhitelistService::UnloadWhitelist(const std::string& id) { |
121 bool result = registered_whitelists_.erase(id) > 0u; | 122 bool result = registered_whitelists_.erase(id) > 0u; |
122 DCHECK(result); | 123 DCHECK(result); |
123 loaded_whitelists_.erase(id); | 124 loaded_whitelists_.erase(id); |
124 NotifyWhitelistsChanged(); | 125 NotifyWhitelistsChanged(); |
125 } | 126 } |
126 | 127 |
127 // static | 128 // static |
(...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
321 void SupervisedUserWhitelistService::NotifyWhitelistsChanged() { | 322 void SupervisedUserWhitelistService::NotifyWhitelistsChanged() { |
322 std::vector<scoped_refptr<SupervisedUserSiteList>> whitelists; | 323 std::vector<scoped_refptr<SupervisedUserSiteList>> whitelists; |
323 GetLoadedWhitelists(&whitelists); | 324 GetLoadedWhitelists(&whitelists); |
324 | 325 |
325 for (const auto& callback : site_lists_changed_callbacks_) | 326 for (const auto& callback : site_lists_changed_callbacks_) |
326 callback.Run(whitelists); | 327 callback.Run(whitelists); |
327 } | 328 } |
328 | 329 |
329 void SupervisedUserWhitelistService::OnWhitelistReady( | 330 void SupervisedUserWhitelistService::OnWhitelistReady( |
330 const std::string& id, | 331 const std::string& id, |
| 332 const base::string16& title, |
331 const base::FilePath& whitelist_path) { | 333 const base::FilePath& whitelist_path) { |
332 // If we did not register the whitelist or it has been unregistered in the | 334 // If we did not register the whitelist or it has been unregistered in the |
333 // mean time, ignore it. | 335 // mean time, ignore it. |
334 if (registered_whitelists_.count(id) == 0u) | 336 if (registered_whitelists_.count(id) == 0u) |
335 return; | 337 return; |
336 | 338 |
337 SupervisedUserSiteList::Load( | 339 SupervisedUserSiteList::Load( |
338 whitelist_path, | 340 title, whitelist_path, |
339 base::Bind(&SupervisedUserWhitelistService::OnWhitelistLoaded, | 341 base::Bind(&SupervisedUserWhitelistService::OnWhitelistLoaded, |
340 weak_ptr_factory_.GetWeakPtr(), id, base::TimeTicks::Now())); | 342 weak_ptr_factory_.GetWeakPtr(), id, base::TimeTicks::Now())); |
341 } | 343 } |
342 | 344 |
343 void SupervisedUserWhitelistService::OnWhitelistLoaded( | 345 void SupervisedUserWhitelistService::OnWhitelistLoaded( |
344 const std::string& id, | 346 const std::string& id, |
345 base::TimeTicks start_time, | 347 base::TimeTicks start_time, |
346 const scoped_refptr<SupervisedUserSiteList>& whitelist) { | 348 const scoped_refptr<SupervisedUserSiteList>& whitelist) { |
347 if (!whitelist) { | 349 if (!whitelist) { |
348 LOG(WARNING) << "Couldn't load whitelist " << id; | 350 LOG(WARNING) << "Couldn't load whitelist " << id; |
349 return; | 351 return; |
350 } | 352 } |
351 | 353 |
352 UMA_HISTOGRAM_TIMES("ManagedUsers.Whitelist.TotalLoadDuration", | 354 UMA_HISTOGRAM_TIMES("ManagedUsers.Whitelist.TotalLoadDuration", |
353 base::TimeTicks::Now() - start_time); | 355 base::TimeTicks::Now() - start_time); |
354 | 356 |
355 // If the whitelist has been unregistered in the mean time, ignore it. | 357 // If the whitelist has been unregistered in the mean time, ignore it. |
356 if (registered_whitelists_.count(id) == 0u) | 358 if (registered_whitelists_.count(id) == 0u) |
357 return; | 359 return; |
358 | 360 |
359 loaded_whitelists_[id] = whitelist; | 361 loaded_whitelists_[id] = whitelist; |
360 NotifyWhitelistsChanged(); | 362 NotifyWhitelistsChanged(); |
361 } | 363 } |
OLD | NEW |