OLD | NEW |
---|---|
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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/chromeos/app_mode/kiosk_app_manager.h" | 5 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager.h" |
6 | 6 |
7 #include <map> | 7 #include <map> |
8 #include <set> | 8 #include <set> |
9 | 9 |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
11 #include "base/files/file_path.h" | 11 #include "base/files/file_path.h" |
12 #include "base/logging.h" | 12 #include "base/logging.h" |
13 #include "base/path_service.h" | 13 #include "base/path_service.h" |
14 #include "base/prefs/pref_registry_simple.h" | 14 #include "base/prefs/pref_registry_simple.h" |
15 #include "base/prefs/pref_service.h" | 15 #include "base/prefs/pref_service.h" |
16 #include "base/prefs/scoped_user_pref_update.h" | 16 #include "base/prefs/scoped_user_pref_update.h" |
17 #include "base/stl_util.h" | 17 #include "base/stl_util.h" |
18 #include "base/sys_info.h" | 18 #include "base/sys_info.h" |
19 #include "chrome/browser/browser_process.h" | 19 #include "chrome/browser/browser_process.h" |
20 #include "chrome/browser/chromeos/app_mode/kiosk_app_data.h" | 20 #include "chrome/browser/chromeos/app_mode/kiosk_app_data.h" |
21 #include "chrome/browser/chromeos/app_mode/kiosk_app_external_loader.h" | 21 #include "chrome/browser/chromeos/app_mode/kiosk_app_external_loader.h" |
22 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager_observer.h" | 22 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager_observer.h" |
23 #include "chrome/browser/chromeos/app_mode/kiosk_external_updater.h" | |
23 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" | 24 #include "chrome/browser/chromeos/policy/browser_policy_connector_chromeos.h" |
24 #include "chrome/browser/chromeos/policy/device_local_account.h" | 25 #include "chrome/browser/chromeos/policy/device_local_account.h" |
25 #include "chrome/browser/chromeos/settings/cros_settings.h" | 26 #include "chrome/browser/chromeos/settings/cros_settings.h" |
26 #include "chrome/browser/chromeos/settings/owner_key_util.h" | 27 #include "chrome/browser/chromeos/settings/owner_key_util.h" |
27 #include "chrome/browser/extensions/external_loader.h" | 28 #include "chrome/browser/extensions/external_loader.h" |
28 #include "chrome/browser/extensions/external_provider_impl.h" | 29 #include "chrome/browser/extensions/external_provider_impl.h" |
29 #include "chrome/common/chrome_paths.h" | 30 #include "chrome/common/chrome_paths.h" |
30 #include "chrome/common/extensions/extension_constants.h" | 31 #include "chrome/common/extensions/extension_constants.h" |
31 #include "chromeos/chromeos_paths.h" | 32 #include "chromeos/chromeos_paths.h" |
32 #include "chromeos/cryptohome/async_method_caller.h" | 33 #include "chromeos/cryptohome/async_method_caller.h" |
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
67 } | 68 } |
68 | 69 |
69 } // namespace | 70 } // namespace |
70 | 71 |
71 // static | 72 // static |
72 const char KioskAppManager::kKioskDictionaryName[] = "kiosk"; | 73 const char KioskAppManager::kKioskDictionaryName[] = "kiosk"; |
73 const char KioskAppManager::kKeyApps[] = "apps"; | 74 const char KioskAppManager::kKeyApps[] = "apps"; |
74 const char KioskAppManager::kKeyAutoLoginState[] = "auto_login_state"; | 75 const char KioskAppManager::kKeyAutoLoginState[] = "auto_login_state"; |
75 const char KioskAppManager::kIconCacheDir[] = "kiosk/icon"; | 76 const char KioskAppManager::kIconCacheDir[] = "kiosk/icon"; |
76 const char KioskAppManager::kCrxCacheDir[] = "kiosk/crx"; | 77 const char KioskAppManager::kCrxCacheDir[] = "kiosk/crx"; |
78 const char KioskAppManager::kCrxUnpackDir[] = "kiosk/unpack"; | |
xiyuan
2014/08/23 18:11:57
We should probably use "/tmp"
jennyz
2014/08/27 00:58:41
Done.
| |
77 | 79 |
78 // static | 80 // static |
79 static base::LazyInstance<KioskAppManager> instance = LAZY_INSTANCE_INITIALIZER; | 81 static base::LazyInstance<KioskAppManager> instance = LAZY_INSTANCE_INITIALIZER; |
80 KioskAppManager* KioskAppManager::Get() { | 82 KioskAppManager* KioskAppManager::Get() { |
81 return instance.Pointer(); | 83 return instance.Pointer(); |
82 } | 84 } |
83 | 85 |
84 // static | 86 // static |
85 void KioskAppManager::Shutdown() { | 87 void KioskAppManager::Shutdown() { |
86 if (instance == NULL) | 88 if (instance == NULL) |
(...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
363 apps_[i]->Load(); | 365 apps_[i]->Load(); |
364 } | 366 } |
365 } | 367 } |
366 | 368 |
367 bool KioskAppManager::HasCachedCrx(const std::string& app_id) const { | 369 bool KioskAppManager::HasCachedCrx(const std::string& app_id) const { |
368 base::FilePath crx_path; | 370 base::FilePath crx_path; |
369 std::string version; | 371 std::string version; |
370 return GetCachedCrx(app_id, &crx_path, &version); | 372 return GetCachedCrx(app_id, &crx_path, &version); |
371 } | 373 } |
372 | 374 |
375 bool KioskAppManager::GetCachedCrx(const std::string& app_id, | |
376 base::FilePath* file_path, | |
377 std::string* version) const { | |
378 return external_cache_->GetExtension(app_id, file_path, version); | |
379 } | |
380 | |
373 void KioskAppManager::AddObserver(KioskAppManagerObserver* observer) { | 381 void KioskAppManager::AddObserver(KioskAppManagerObserver* observer) { |
374 observers_.AddObserver(observer); | 382 observers_.AddObserver(observer); |
375 } | 383 } |
376 | 384 |
377 void KioskAppManager::RemoveObserver(KioskAppManagerObserver* observer) { | 385 void KioskAppManager::RemoveObserver(KioskAppManagerObserver* observer) { |
378 observers_.RemoveObserver(observer); | 386 observers_.RemoveObserver(observer); |
379 } | 387 } |
380 | 388 |
381 extensions::ExternalLoader* KioskAppManager::CreateExternalLoader() { | 389 extensions::ExternalLoader* KioskAppManager::CreateExternalLoader() { |
382 if (external_loader_created_) { | 390 if (external_loader_created_) { |
(...skipping 17 matching lines...) Expand all Loading... | |
400 } else { | 408 } else { |
401 LOG(ERROR) << "Can't find app in the cached externsions" | 409 LOG(ERROR) << "Can't find app in the cached externsions" |
402 << " id = " << id; | 410 << " id = " << id; |
403 } | 411 } |
404 } | 412 } |
405 | 413 |
406 void KioskAppManager::UpdateExternalCache() { | 414 void KioskAppManager::UpdateExternalCache() { |
407 UpdateAppData(); | 415 UpdateAppData(); |
408 } | 416 } |
409 | 417 |
418 void KioskAppManager::OnKioskAppCacheUpdated(const std::string& app_id) { | |
419 FOR_EACH_OBSERVER( | |
420 KioskAppManagerObserver, observers_, OnKioskAppCacheUpdated(app_id)); | |
421 } | |
422 | |
410 KioskAppManager::KioskAppManager() | 423 KioskAppManager::KioskAppManager() |
411 : ownership_established_(false), external_loader_created_(false) { | 424 : ownership_established_(false), external_loader_created_(false) { |
412 base::FilePath cache_dir; | 425 base::FilePath cache_dir; |
413 GetCrxCacheDir(&cache_dir); | 426 GetCrxCacheDir(&cache_dir); |
414 external_cache_.reset( | 427 external_cache_.reset( |
415 new ExternalCache(cache_dir, | 428 new ExternalCache(cache_dir, |
416 g_browser_process->system_request_context(), | 429 g_browser_process->system_request_context(), |
417 GetBackgroundTaskRunner(), | 430 GetBackgroundTaskRunner(), |
418 this, | 431 this, |
419 true /* always_check_updates */, | 432 true /* always_check_updates */, |
420 false /* wait_for_cache_initialization */)); | 433 false /* wait_for_cache_initialization */)); |
421 UpdateAppData(); | 434 UpdateAppData(); |
422 local_accounts_subscription_ = | 435 local_accounts_subscription_ = |
423 CrosSettings::Get()->AddSettingsObserver( | 436 CrosSettings::Get()->AddSettingsObserver( |
424 kAccountsPrefDeviceLocalAccounts, | 437 kAccountsPrefDeviceLocalAccounts, |
425 base::Bind(&KioskAppManager::UpdateAppData, base::Unretained(this))); | 438 base::Bind(&KioskAppManager::UpdateAppData, base::Unretained(this))); |
426 local_account_auto_login_id_subscription_ = | 439 local_account_auto_login_id_subscription_ = |
427 CrosSettings::Get()->AddSettingsObserver( | 440 CrosSettings::Get()->AddSettingsObserver( |
428 kAccountsPrefDeviceLocalAccountAutoLoginId, | 441 kAccountsPrefDeviceLocalAccountAutoLoginId, |
429 base::Bind(&KioskAppManager::UpdateAppData, base::Unretained(this))); | 442 base::Bind(&KioskAppManager::UpdateAppData, base::Unretained(this))); |
430 } | 443 } |
431 | 444 |
432 KioskAppManager::~KioskAppManager() {} | 445 KioskAppManager::~KioskAppManager() {} |
433 | 446 |
447 void KioskAppManager::MonitorKioskExternalUpdate() { | |
448 base::FilePath cache_dir; | |
449 GetCrxCacheDir(&cache_dir); | |
450 base::FilePath unpack_dir; | |
451 GetCrxUnpackDir(&unpack_dir); | |
452 usb_stick_updater_ = new KioskExternalUpdater( | |
453 GetBackgroundTaskRunner(), cache_dir, unpack_dir); | |
454 } | |
455 | |
434 void KioskAppManager::CleanUp() { | 456 void KioskAppManager::CleanUp() { |
435 local_accounts_subscription_.reset(); | 457 local_accounts_subscription_.reset(); |
436 local_account_auto_login_id_subscription_.reset(); | 458 local_account_auto_login_id_subscription_.reset(); |
437 apps_.clear(); | 459 apps_.clear(); |
460 usb_stick_updater_ = NULL; | |
438 external_cache_.reset(); | 461 external_cache_.reset(); |
439 } | 462 } |
440 | 463 |
441 const KioskAppData* KioskAppManager::GetAppData( | 464 const KioskAppData* KioskAppManager::GetAppData( |
442 const std::string& app_id) const { | 465 const std::string& app_id) const { |
443 for (size_t i = 0; i < apps_.size(); ++i) { | 466 for (size_t i = 0; i < apps_.size(); ++i) { |
444 const KioskAppData* data = apps_[i]; | 467 const KioskAppData* data = apps_[i]; |
445 if (data->app_id() == app_id) | 468 if (data->app_id() == app_id) |
446 return data; | 469 return data; |
447 } | 470 } |
(...skipping 131 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
579 dict_update->SetInteger(kKeyAutoLoginState, state); | 602 dict_update->SetInteger(kKeyAutoLoginState, state); |
580 prefs->CommitPendingWrite(); | 603 prefs->CommitPendingWrite(); |
581 } | 604 } |
582 | 605 |
583 void KioskAppManager::GetCrxCacheDir(base::FilePath* cache_dir) { | 606 void KioskAppManager::GetCrxCacheDir(base::FilePath* cache_dir) { |
584 base::FilePath user_data_dir; | 607 base::FilePath user_data_dir; |
585 CHECK(PathService::Get(chrome::DIR_USER_DATA, &user_data_dir)); | 608 CHECK(PathService::Get(chrome::DIR_USER_DATA, &user_data_dir)); |
586 *cache_dir = user_data_dir.AppendASCII(kCrxCacheDir); | 609 *cache_dir = user_data_dir.AppendASCII(kCrxCacheDir); |
587 } | 610 } |
588 | 611 |
589 bool KioskAppManager::GetCachedCrx(const std::string& app_id, | 612 void KioskAppManager::GetCrxUnpackDir(base::FilePath* unpack_dir) { |
590 base::FilePath* file_path, | 613 base::FilePath user_data_dir; |
591 std::string* version) const { | 614 CHECK(PathService::Get(chrome::DIR_USER_DATA, &user_data_dir)); |
592 return external_cache_->GetExtension(app_id, file_path, version); | 615 *unpack_dir = user_data_dir.AppendASCII(kCrxUnpackDir); |
593 } | 616 } |
594 | 617 |
595 } // namespace chromeos | 618 } // namespace chromeos |
OLD | NEW |