| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/extensions/crx_installer.h" | 5 #include "chrome/browser/extensions/crx_installer.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" |
| (...skipping 441 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 452 extension_, histogram_name.c_str()); | 452 extension_, histogram_name.c_str()); |
| 453 | 453 |
| 454 // Kill the theme loading bubble. | 454 // Kill the theme loading bubble. |
| 455 content::NotificationService* service = | 455 content::NotificationService* service = |
| 456 content::NotificationService::current(); | 456 content::NotificationService::current(); |
| 457 service->Notify(chrome::NOTIFICATION_NO_THEME_DETECTED, | 457 service->Notify(chrome::NOTIFICATION_NO_THEME_DETECTED, |
| 458 content::Source<CrxInstaller>(this), | 458 content::Source<CrxInstaller>(this), |
| 459 content::NotificationService::NoDetails()); | 459 content::NotificationService::NoDetails()); |
| 460 Release(); // balanced in ConfirmInstall(). | 460 Release(); // balanced in ConfirmInstall(). |
| 461 | 461 |
| 462 NotifyCrxInstallComplete(); | 462 NotifyCrxInstallComplete(NULL); |
| 463 | 463 |
| 464 // We're done. Since we don't post any more tasks to ourself, our ref count | 464 // We're done. Since we don't post any more tasks to ourself, our ref count |
| 465 // should go to zero and we die. The destructor will clean up the temp dir. | 465 // should go to zero and we die. The destructor will clean up the temp dir. |
| 466 } | 466 } |
| 467 | 467 |
| 468 void CrxInstaller::CompleteInstall() { | 468 void CrxInstaller::CompleteInstall() { |
| 469 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); | 469 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); |
| 470 | 470 |
| 471 if (!current_version_.empty()) { | 471 if (!current_version_.empty()) { |
| 472 scoped_ptr<Version> current_version( | 472 scoped_ptr<Version> current_version( |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 533 // This isn't really necessary, it is only used because unit tests expect to | 533 // This isn't really necessary, it is only used because unit tests expect to |
| 534 // see errors get reported via this interface. | 534 // see errors get reported via this interface. |
| 535 // | 535 // |
| 536 // TODO(aa): Need to go through unit tests and clean them up too, probably get | 536 // TODO(aa): Need to go through unit tests and clean them up too, probably get |
| 537 // rid of this line. | 537 // rid of this line. |
| 538 ExtensionErrorReporter::GetInstance()->ReportError(error, false); // quiet | 538 ExtensionErrorReporter::GetInstance()->ReportError(error, false); // quiet |
| 539 | 539 |
| 540 if (client_) | 540 if (client_) |
| 541 client_->OnInstallFailure(error); | 541 client_->OnInstallFailure(error); |
| 542 | 542 |
| 543 NotifyCrxInstallComplete(); | 543 NotifyCrxInstallComplete(NULL); |
| 544 } | 544 } |
| 545 | 545 |
| 546 void CrxInstaller::ReportSuccessFromFileThread() { | 546 void CrxInstaller::ReportSuccessFromFileThread() { |
| 547 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); | 547 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); |
| 548 | 548 |
| 549 // Tracking number of extensions installed by users | 549 // Tracking number of extensions installed by users |
| 550 if (install_cause() == extension_misc::INSTALL_CAUSE_USER_DOWNLOAD) { | 550 if (install_cause() == extension_misc::INSTALL_CAUSE_USER_DOWNLOAD) { |
| 551 UMA_HISTOGRAM_ENUMERATION("Extensions.ExtensionInstalled", 1, 2); | 551 UMA_HISTOGRAM_ENUMERATION("Extensions.ExtensionInstalled", 1, 2); |
| 552 | 552 |
| 553 static bool default_apps_trial_exists = | 553 static bool default_apps_trial_exists = |
| (...skipping 26 matching lines...) Expand all Loading... |
| 580 // the install (client_ is non NULL), or we are allowed to install this | 580 // the install (client_ is non NULL), or we are allowed to install this |
| 581 // silently. We only track granted permissions for INTERNAL extensions. | 581 // silently. We only track granted permissions for INTERNAL extensions. |
| 582 if ((client_ || allow_silent_install_) && | 582 if ((client_ || allow_silent_install_) && |
| 583 extension_->location() == Extension::INTERNAL) | 583 extension_->location() == Extension::INTERNAL) |
| 584 frontend_weak_->GrantPermissions(extension_); | 584 frontend_weak_->GrantPermissions(extension_); |
| 585 | 585 |
| 586 // Tell the frontend about the installation and hand off ownership of | 586 // Tell the frontend about the installation and hand off ownership of |
| 587 // extension_ to it. | 587 // extension_ to it. |
| 588 frontend_weak_->OnExtensionInstalled(extension_, is_gallery_install(), | 588 frontend_weak_->OnExtensionInstalled(extension_, is_gallery_install(), |
| 589 page_index_); | 589 page_index_); |
| 590 |
| 591 NotifyCrxInstallComplete(extension_.get()); |
| 592 |
| 590 extension_ = NULL; | 593 extension_ = NULL; |
| 591 | 594 |
| 592 NotifyCrxInstallComplete(); | |
| 593 | |
| 594 // We're done. We don't post any more tasks to ourselves so we are deleted | 595 // We're done. We don't post any more tasks to ourselves so we are deleted |
| 595 // soon. | 596 // soon. |
| 596 } | 597 } |
| 597 | 598 |
| 598 void CrxInstaller::NotifyCrxInstallComplete() { | 599 void CrxInstaller::NotifyCrxInstallComplete(const Extension* extension) { |
| 599 // Some users (such as the download shelf) need to know when a | 600 // Some users (such as the download shelf) need to know when a |
| 600 // CRXInstaller is done. Listening for the EXTENSION_* events | 601 // CRXInstaller is done. Listening for the EXTENSION_* events |
| 601 // is problematic because they don't know anything about the | 602 // is problematic because they don't know anything about the |
| 602 // extension before it is unpacked, so they can not filter based | 603 // extension before it is unpacked, so they cannot filter based |
| 603 // on the extension. | 604 // on the extension. |
| 604 content::NotificationService::current()->Notify( | 605 content::NotificationService::current()->Notify( |
| 605 chrome::NOTIFICATION_CRX_INSTALLER_DONE, | 606 chrome::NOTIFICATION_CRX_INSTALLER_DONE, |
| 606 content::Source<CrxInstaller>(this), | 607 content::Source<CrxInstaller>(this), |
| 607 content::NotificationService::NoDetails()); | 608 content::Details<const Extension>(extension)); |
| 608 } | 609 } |
| OLD | NEW |