Chromium Code Reviews| 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_data.h" | 5 #include "chrome/browser/chromeos/app_mode/kiosk_app_data.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/file_util.h" | 10 #include "base/file_util.h" |
| 11 #include "base/json/json_writer.h" | 11 #include "base/json/json_writer.h" |
| 12 #include "base/memory/ref_counted_memory.h" | 12 #include "base/memory/ref_counted_memory.h" |
| 13 #include "base/prefs/pref_service.h" | 13 #include "base/prefs/pref_service.h" |
| 14 #include "base/prefs/scoped_user_pref_update.h" | 14 #include "base/prefs/scoped_user_pref_update.h" |
| 15 #include "base/threading/sequenced_worker_pool.h" | 15 #include "base/threading/sequenced_worker_pool.h" |
| 16 #include "base/values.h" | 16 #include "base/values.h" |
| 17 #include "chrome/browser/browser_process.h" | 17 #include "chrome/browser/browser_process.h" |
| 18 #include "chrome/browser/chromeos/app_mode/kiosk_app_data_delegate.h" | 18 #include "chrome/browser/chromeos/app_mode/kiosk_app_data_delegate.h" |
| 19 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager.h" | 19 #include "chrome/browser/chromeos/app_mode/kiosk_app_manager.h" |
| 20 #include "chrome/browser/extensions/extension_service.h" | |
| 21 #include "chrome/browser/extensions/extension_system.h" | |
| 22 #include "chrome/browser/extensions/image_loader.h" | |
| 20 #include "chrome/browser/extensions/webstore_data_fetcher.h" | 23 #include "chrome/browser/extensions/webstore_data_fetcher.h" |
| 21 #include "chrome/browser/extensions/webstore_install_helper.h" | 24 #include "chrome/browser/extensions/webstore_install_helper.h" |
| 22 #include "chrome/browser/image_decoder.h" | 25 #include "chrome/browser/image_decoder.h" |
| 26 #include "chrome/browser/profiles/profile.h" | |
| 23 #include "chrome/common/extensions/extension_constants.h" | 27 #include "chrome/common/extensions/extension_constants.h" |
| 28 #include "chrome/common/extensions/manifest_handlers/icons_handler.h" | |
| 24 #include "content/public/browser/browser_thread.h" | 29 #include "content/public/browser/browser_thread.h" |
| 25 #include "extensions/common/manifest.h" | 30 #include "extensions/common/manifest.h" |
| 26 #include "extensions/common/manifest_constants.h" | 31 #include "extensions/common/manifest_constants.h" |
| 27 #include "ui/gfx/codec/png_codec.h" | 32 #include "ui/gfx/codec/png_codec.h" |
| 33 #include "ui/gfx/image/image.h" | |
| 28 | 34 |
| 29 using content::BrowserThread; | 35 using content::BrowserThread; |
| 30 | 36 |
| 31 namespace chromeos { | 37 namespace chromeos { |
| 32 | 38 |
| 33 namespace { | 39 namespace { |
| 34 | 40 |
| 35 // Keys for local state data. See sample layout in KioskAppManager. | 41 // Keys for local state data. See sample layout in KioskAppManager. |
| 36 const char kKeyName[] = "name"; | 42 const char kKeyName[] = "name"; |
| 37 const char kKeyIcon[] = "icon"; | 43 const char kKeyIcon[] = "icon"; |
| (...skipping 243 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 281 std::string app_key = std::string(KioskAppManager::kKeyApps) + '.' + app_id_; | 287 std::string app_key = std::string(KioskAppManager::kKeyApps) + '.' + app_id_; |
| 282 dict_update->Remove(app_key, NULL); | 288 dict_update->Remove(app_key, NULL); |
| 283 | 289 |
| 284 if (!icon_path_.empty()) { | 290 if (!icon_path_.empty()) { |
| 285 BrowserThread::PostBlockingPoolTask( | 291 BrowserThread::PostBlockingPoolTask( |
| 286 FROM_HERE, | 292 FROM_HERE, |
| 287 base::Bind(base::IgnoreResult(&base::DeleteFile), icon_path_, false)); | 293 base::Bind(base::IgnoreResult(&base::DeleteFile), icon_path_, false)); |
| 288 } | 294 } |
| 289 } | 295 } |
| 290 | 296 |
| 297 void KioskAppData::UpdateFromProfile(Profile* profile, | |
| 298 const extensions::Extension* app) { | |
| 299 SetStatus(STATUS_LOADING); | |
| 300 | |
| 301 if (!app) { | |
| 302 app = extensions::ExtensionSystem::Get(profile) | |
| 303 ->extension_service() | |
| 304 ->GetInstalledExtension(app_id_); | |
| 305 } | |
| 306 | |
| 307 DCHECK_EQ(app_id_, app->id()); | |
| 308 | |
| 309 name_ = app->name(); | |
| 310 | |
| 311 const int kIconSize = extension_misc::EXTENSION_ICON_LARGE; | |
| 312 extensions::ExtensionResource image = extensions::IconsInfo::GetIconResource( | |
| 313 app, kIconSize, ExtensionIconSet::MATCH_BIGGER); | |
| 314 extensions::ImageLoader::Get(profile)->LoadImageAsync( | |
| 315 app, image, gfx::Size(kIconSize, kIconSize), | |
| 316 base::Bind(&KioskAppData::OnExtensionIconLoaded, AsWeakPtr())); | |
| 317 } | |
| 318 | |
| 291 bool KioskAppData::IsLoading() const { | 319 bool KioskAppData::IsLoading() const { |
| 292 return status_ == STATUS_LOADING; | 320 return status_ == STATUS_LOADING; |
| 293 } | 321 } |
| 294 | 322 |
| 295 void KioskAppData::SetStatus(Status status) { | 323 void KioskAppData::SetStatus(Status status) { |
| 296 if (status_ == status) | 324 if (status_ == status) |
| 297 return; | 325 return; |
| 298 | 326 |
| 299 status_ = status; | 327 status_ = status; |
| 300 | 328 |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 347 std::string icon_path_key = app_key + '.' + kKeyIcon; | 375 std::string icon_path_key = app_key + '.' + kKeyIcon; |
| 348 | 376 |
| 349 PrefService* local_state = g_browser_process->local_state(); | 377 PrefService* local_state = g_browser_process->local_state(); |
| 350 DictionaryPrefUpdate dict_update(local_state, | 378 DictionaryPrefUpdate dict_update(local_state, |
| 351 KioskAppManager::kKioskDictionaryName); | 379 KioskAppManager::kKioskDictionaryName); |
| 352 dict_update->SetString(name_key, name); | 380 dict_update->SetString(name_key, name); |
| 353 dict_update->SetString(icon_path_key, icon_path.value()); | 381 dict_update->SetString(icon_path_key, icon_path.value()); |
| 354 icon_path_ = icon_path; | 382 icon_path_ = icon_path; |
| 355 } | 383 } |
| 356 | 384 |
| 357 void KioskAppData::OnIconLoadSuccess( | 385 void KioskAppData::SetCachedIcon(const SkBitmap& icon) { |
|
Tim Song
2014/01/13 23:41:08
nit: This function is also calling SetCache() at t
xiyuan
2014/01/14 00:15:07
Done.
| |
| 358 const scoped_refptr<base::RefCountedString>& raw_icon, | |
| 359 const gfx::ImageSkia& icon) { | |
| 360 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 361 raw_icon_ = raw_icon; | |
| 362 icon_ = icon; | |
| 363 SetStatus(STATUS_LOADED); | |
| 364 } | |
| 365 | |
| 366 void KioskAppData::OnIconLoadFailure() { | |
| 367 // Re-fetch data from web store when failed to load cached data. | |
| 368 StartFetch(); | |
| 369 } | |
| 370 | |
| 371 void KioskAppData::OnWebstoreParseSuccess(const SkBitmap& icon) { | |
| 372 icon_ = gfx::ImageSkia::CreateFrom1xBitmap(icon); | 386 icon_ = gfx::ImageSkia::CreateFrom1xBitmap(icon); |
| 373 icon_.MakeThreadSafe(); | 387 icon_.MakeThreadSafe(); |
| 374 | 388 |
| 375 std::vector<unsigned char> image_data; | 389 std::vector<unsigned char> image_data; |
| 376 CHECK(gfx::PNGCodec::EncodeBGRASkBitmap(icon, false, &image_data)); | 390 CHECK(gfx::PNGCodec::EncodeBGRASkBitmap(icon, false, &image_data)); |
| 377 raw_icon_ = new base::RefCountedString; | 391 raw_icon_ = new base::RefCountedString; |
| 378 raw_icon_->data().assign(image_data.begin(), image_data.end()); | 392 raw_icon_->data().assign(image_data.begin(), image_data.end()); |
| 379 | 393 |
| 380 base::FilePath cache_dir; | 394 base::FilePath cache_dir; |
| 381 if (delegate_) | 395 if (delegate_) |
| 382 delegate_->GetKioskAppIconCacheDir(&cache_dir); | 396 delegate_->GetKioskAppIconCacheDir(&cache_dir); |
| 383 | 397 |
| 384 base::FilePath icon_path = | 398 base::FilePath icon_path = |
| 385 cache_dir.AppendASCII(app_id_).AddExtension(kIconFileExtension); | 399 cache_dir.AppendASCII(app_id_).AddExtension(kIconFileExtension); |
| 386 BrowserThread::GetBlockingPool()->PostTask( | 400 BrowserThread::GetBlockingPool()->PostTask( |
| 387 FROM_HERE, | 401 FROM_HERE, |
| 388 base::Bind(&SaveIconToLocalOnBlockingPool, icon_path, raw_icon_)); | 402 base::Bind(&SaveIconToLocalOnBlockingPool, icon_path, raw_icon_)); |
| 389 | 403 |
| 390 SetCache(name_, icon_path); | 404 SetCache(name_, icon_path); |
| 405 } | |
| 406 | |
| 407 void KioskAppData::OnExtensionIconLoaded(const gfx::Image& icon) { | |
| 408 if (icon.IsEmpty()) { | |
| 409 LOG(WARNING) << "Failed to load icon from installed app" | |
| 410 << ", id=" << app_id_; | |
| 411 SetCachedIcon(*extensions::IconsInfo::GetDefaultAppIcon().bitmap()); | |
| 412 } else { | |
| 413 SetCachedIcon(icon.AsBitmap()); | |
| 414 } | |
| 415 | |
| 391 SetStatus(STATUS_LOADED); | 416 SetStatus(STATUS_LOADED); |
| 392 } | 417 } |
| 393 | 418 |
| 419 void KioskAppData::OnIconLoadSuccess( | |
| 420 const scoped_refptr<base::RefCountedString>& raw_icon, | |
| 421 const gfx::ImageSkia& icon) { | |
| 422 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | |
| 423 raw_icon_ = raw_icon; | |
| 424 icon_ = icon; | |
| 425 SetStatus(STATUS_LOADED); | |
| 426 } | |
| 427 | |
| 428 void KioskAppData::OnIconLoadFailure() { | |
| 429 // Re-fetch data from web store when failed to load cached data. | |
| 430 StartFetch(); | |
| 431 } | |
| 432 | |
| 433 void KioskAppData::OnWebstoreParseSuccess(const SkBitmap& icon) { | |
| 434 SetCachedIcon(icon); | |
| 435 SetStatus(STATUS_LOADED); | |
| 436 } | |
| 437 | |
| 394 void KioskAppData::OnWebstoreParseFailure() { | 438 void KioskAppData::OnWebstoreParseFailure() { |
| 395 SetStatus(STATUS_ERROR); | 439 SetStatus(STATUS_ERROR); |
| 396 } | 440 } |
| 397 | 441 |
| 398 void KioskAppData::StartFetch() { | 442 void KioskAppData::StartFetch() { |
| 399 webstore_fetcher_.reset(new extensions::WebstoreDataFetcher( | 443 webstore_fetcher_.reset(new extensions::WebstoreDataFetcher( |
| 400 this, | 444 this, |
| 401 GetRequestContextGetter(), | 445 GetRequestContextGetter(), |
| 402 GURL(), | 446 GURL(), |
| 403 app_id_)); | 447 app_id_)); |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 454 if (!response->GetString(key, value)) { | 498 if (!response->GetString(key, value)) { |
| 455 LOG(ERROR) << "Webstore response error (" << key | 499 LOG(ERROR) << "Webstore response error (" << key |
| 456 << "): " << ValueToString(response); | 500 << "): " << ValueToString(response); |
| 457 OnWebstoreResponseParseFailure(kInvalidWebstoreResponseError); | 501 OnWebstoreResponseParseFailure(kInvalidWebstoreResponseError); |
| 458 return false; | 502 return false; |
| 459 } | 503 } |
| 460 return true; | 504 return true; |
| 461 } | 505 } |
| 462 | 506 |
| 463 } // namespace chromeos | 507 } // namespace chromeos |
| OLD | NEW |