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

Side by Side Diff: chrome/browser/chromeos/app_mode/kiosk_app_manager.cc

Issue 491403003: Update cached kiosk app crx from usb stick. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 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
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698