Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/download/chrome_download_manager_delegate.h" | 5 #include "chrome/browser/download/chrome_download_manager_delegate.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/bind_helpers.h" | 10 #include "base/bind_helpers.h" |
| 11 #include "base/callback.h" | 11 #include "base/callback.h" |
| 12 #include "base/file_util.h" | 12 #include "base/file_util.h" |
| 13 #include "base/rand_util.h" | 13 #include "base/rand_util.h" |
| 14 #include "base/stringprintf.h" | 14 #include "base/stringprintf.h" |
| 15 #include "base/time.h" | 15 #include "base/time.h" |
| 16 #include "base/utf_string_conversions.h" | 16 #include "base/utf_string_conversions.h" |
| 17 #include "chrome/browser/api/prefs/pref_member.h" | 17 #include "chrome/browser/api/prefs/pref_member.h" |
| 18 #include "chrome/browser/browser_process.h" | 18 #include "chrome/browser/browser_process.h" |
| 19 #include "chrome/browser/download/download_completion_blocker.h" | 19 #include "chrome/browser/download/download_completion_blocker.h" |
| 20 #include "chrome/browser/download/download_crx_util.h" | 20 #include "chrome/browser/download/download_crx_util.h" |
| 21 #include "chrome/browser/download/download_extensions.h" | 21 #include "chrome/browser/download/download_extensions.h" |
| 22 #include "chrome/browser/download/download_file_picker.h" | 22 #include "chrome/browser/download/download_file_picker.h" |
| 23 #include "chrome/browser/download/download_history.h" | 23 #include "chrome/browser/download/download_history.h" |
| 24 #include "chrome/browser/download/download_path_reservation_tracker.h" | 24 #include "chrome/browser/download/download_path_reservation_tracker.h" |
| 25 #include "chrome/browser/download/download_prefs.h" | 25 #include "chrome/browser/download/download_prefs.h" |
| 26 #include "chrome/browser/download/download_service.h" | |
| 27 #include "chrome/browser/download/download_service_factory.h" | |
| 26 #include "chrome/browser/download/download_status_updater.h" | 28 #include "chrome/browser/download/download_status_updater.h" |
| 27 #include "chrome/browser/download/download_util.h" | 29 #include "chrome/browser/download/download_util.h" |
| 28 #include "chrome/browser/download/save_package_file_picker.h" | 30 #include "chrome/browser/download/save_package_file_picker.h" |
| 29 #include "chrome/browser/extensions/api/downloads/downloads_api.h" | 31 #include "chrome/browser/extensions/api/downloads/downloads_api.h" |
| 30 #include "chrome/browser/extensions/crx_installer.h" | 32 #include "chrome/browser/extensions/crx_installer.h" |
| 31 #include "chrome/browser/extensions/extension_service.h" | 33 #include "chrome/browser/extensions/extension_service.h" |
| 34 #include "chrome/browser/history/history.h" | |
| 35 #include "chrome/browser/history/history_service_factory.h" | |
| 32 #include "chrome/browser/intents/web_intents_util.h" | 36 #include "chrome/browser/intents/web_intents_util.h" |
| 33 #include "chrome/browser/prefs/pref_service.h" | 37 #include "chrome/browser/prefs/pref_service.h" |
| 34 #include "chrome/browser/profiles/profile.h" | 38 #include "chrome/browser/profiles/profile.h" |
| 35 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 39 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
| 36 #include "chrome/browser/ui/browser_tabstrip.h" | 40 #include "chrome/browser/ui/browser_tabstrip.h" |
| 37 #include "chrome/common/chrome_notification_types.h" | 41 #include "chrome/common/chrome_notification_types.h" |
| 38 #include "chrome/common/extensions/extension_switch_utils.h" | 42 #include "chrome/common/extensions/extension_switch_utils.h" |
| 39 #include "chrome/common/extensions/user_script.h" | 43 #include "chrome/common/extensions/user_script.h" |
| 40 #include "chrome/common/pref_names.h" | 44 #include "chrome/common/pref_names.h" |
| 41 #include "content/public/browser/download_item.h" | 45 #include "content/public/browser/download_item.h" |
| (...skipping 103 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 145 : profile_(profile), | 149 : profile_(profile), |
| 146 next_download_id_(0), | 150 next_download_id_(0), |
| 147 download_prefs_(new DownloadPrefs(profile)) { | 151 download_prefs_(new DownloadPrefs(profile)) { |
| 148 } | 152 } |
| 149 | 153 |
| 150 ChromeDownloadManagerDelegate::~ChromeDownloadManagerDelegate() { | 154 ChromeDownloadManagerDelegate::~ChromeDownloadManagerDelegate() { |
| 151 } | 155 } |
| 152 | 156 |
| 153 void ChromeDownloadManagerDelegate::SetDownloadManager(DownloadManager* dm) { | 157 void ChromeDownloadManagerDelegate::SetDownloadManager(DownloadManager* dm) { |
| 154 download_manager_ = dm; | 158 download_manager_ = dm; |
| 155 download_history_.reset(new DownloadHistory(profile_)); | |
| 156 if (!profile_->IsOffTheRecord()) { | |
| 157 // DownloadManager should not be RefCountedThreadSafe. | |
| 158 // ChromeDownloadManagerDelegate outlives DownloadManager, and | |
| 159 // DownloadHistory uses a scoped canceller to cancel tasks when it is | |
| 160 // deleted. Almost all callbacks to DownloadManager should use weak pointers | |
| 161 // or bounce off a container object that uses ManagerGoingDown() to simulate | |
| 162 // a weak pointer. | |
| 163 download_history_->Load( | |
| 164 base::Bind(&DownloadManager::OnPersistentStoreQueryComplete, | |
| 165 download_manager_)); | |
| 166 } | |
| 167 #if !defined(OS_ANDROID) | 159 #if !defined(OS_ANDROID) |
| 168 extension_event_router_.reset(new ExtensionDownloadsEventRouter( | 160 extension_event_router_.reset(new ExtensionDownloadsEventRouter( |
| 169 profile_, download_manager_)); | 161 profile_, download_manager_)); |
| 170 #endif | 162 #endif |
| 163 | |
| 164 if (!profile_->IsOffTheRecord()) { | |
| 165 HistoryService* hs = HistoryServiceFactory::GetForProfile( | |
| 166 profile_, Profile::EXPLICIT_ACCESS); | |
| 167 if (hs) | |
| 168 download_history_.reset(new DownloadHistory(download_manager_, hs)); | |
|
Randy Smith (Not in Mondays)
2012/09/24 18:03:25
Why here rather than on DownloadService? CDMD is
benjhayden
2012/11/02 17:21:37
Hm. How would you feel about making CDMD::CheckVis
Randy Smith (Not in Mondays)
2012/11/02 23:31:24
I'd be good with that.
benjhayden
2012/11/06 20:01:14
Done.
| |
| 169 } | |
| 170 } | |
| 171 | |
| 172 void ChromeDownloadManagerDelegate::AddHistoryObserver( | |
| 173 DownloadHistory::Observer* observer) { | |
| 174 if (download_history_.get()) | |
| 175 download_history_->AddObserver(observer); | |
| 176 } | |
| 177 | |
| 178 void ChromeDownloadManagerDelegate::RemoveHistoryObserver( | |
| 179 DownloadHistory::Observer* observer) { | |
| 180 if (download_history_.get()) | |
| 181 download_history_->RemoveObserver(observer); | |
| 171 } | 182 } |
| 172 | 183 |
| 173 void ChromeDownloadManagerDelegate::Shutdown() { | 184 void ChromeDownloadManagerDelegate::Shutdown() { |
| 174 download_history_.reset(); | 185 download_history_.reset(); |
| 175 download_prefs_.reset(); | 186 download_prefs_.reset(); |
| 176 #if !defined(OS_ANDROID) | 187 #if !defined(OS_ANDROID) |
| 177 extension_event_router_.reset(); | 188 extension_event_router_.reset(); |
| 178 #endif | 189 #endif |
| 179 } | 190 } |
| 180 | 191 |
| (...skipping 302 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 483 | 494 |
| 484 bool ChromeDownloadManagerDelegate::GenerateFileHash() { | 495 bool ChromeDownloadManagerDelegate::GenerateFileHash() { |
| 485 #if defined(ENABLE_SAFE_BROWSING) | 496 #if defined(ENABLE_SAFE_BROWSING) |
| 486 return profile_->GetPrefs()->GetBoolean(prefs::kSafeBrowsingEnabled) && | 497 return profile_->GetPrefs()->GetBoolean(prefs::kSafeBrowsingEnabled) && |
| 487 g_browser_process->safe_browsing_service()->DownloadBinHashNeeded(); | 498 g_browser_process->safe_browsing_service()->DownloadBinHashNeeded(); |
| 488 #else | 499 #else |
| 489 return false; | 500 return false; |
| 490 #endif | 501 #endif |
| 491 } | 502 } |
| 492 | 503 |
| 493 void ChromeDownloadManagerDelegate::AddItemToPersistentStore( | |
| 494 DownloadItem* item) { | |
| 495 if (profile_->IsOffTheRecord()) { | |
| 496 OnItemAddedToPersistentStore( | |
| 497 item->GetId(), download_history_->GetNextFakeDbHandle()); | |
| 498 return; | |
| 499 } | |
| 500 download_history_->AddEntry(item, | |
| 501 base::Bind(&ChromeDownloadManagerDelegate::OnItemAddedToPersistentStore, | |
| 502 this)); | |
| 503 } | |
| 504 | |
| 505 void ChromeDownloadManagerDelegate::UpdateItemInPersistentStore( | |
| 506 DownloadItem* item) { | |
| 507 download_history_->UpdateEntry(item); | |
| 508 } | |
| 509 | |
| 510 void ChromeDownloadManagerDelegate::UpdatePathForItemInPersistentStore( | |
| 511 DownloadItem* item, | |
| 512 const FilePath& new_path) { | |
| 513 download_history_->UpdateDownloadPath(item, new_path); | |
| 514 } | |
| 515 | |
| 516 void ChromeDownloadManagerDelegate::RemoveItemFromPersistentStore( | |
| 517 DownloadItem* item) { | |
| 518 download_history_->RemoveEntry(item); | |
| 519 } | |
| 520 | |
| 521 void ChromeDownloadManagerDelegate::RemoveItemsFromPersistentStoreBetween( | |
| 522 base::Time remove_begin, | |
| 523 base::Time remove_end) { | |
| 524 if (profile_->IsOffTheRecord()) | |
| 525 return; | |
| 526 download_history_->RemoveEntriesBetween(remove_begin, remove_end); | |
| 527 } | |
| 528 | |
| 529 void ChromeDownloadManagerDelegate::GetSaveDir(BrowserContext* browser_context, | 504 void ChromeDownloadManagerDelegate::GetSaveDir(BrowserContext* browser_context, |
| 530 FilePath* website_save_dir, | 505 FilePath* website_save_dir, |
| 531 FilePath* download_save_dir, | 506 FilePath* download_save_dir, |
| 532 bool* skip_dir_check) { | 507 bool* skip_dir_check) { |
| 533 Profile* profile = Profile::FromBrowserContext(browser_context); | 508 Profile* profile = Profile::FromBrowserContext(browser_context); |
| 534 PrefService* prefs = profile->GetPrefs(); | 509 PrefService* prefs = profile->GetPrefs(); |
| 535 | 510 |
| 536 // Check whether the preference has the preferred directory for saving file. | 511 // Check whether the preference has the preferred directory for saving file. |
| 537 // If not, initialize it with default directory. | 512 // If not, initialize it with default directory. |
| 538 if (!prefs->FindPreference(prefs::kSaveFileDefaultDirectory)) { | 513 if (!prefs->FindPreference(prefs::kSaveFileDefaultDirectory)) { |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 631 DownloadPathReservationTracker::GetReservedPath( | 606 DownloadPathReservationTracker::GetReservedPath( |
| 632 download, target_path, default_download_path, should_uniquify_path, | 607 download, target_path, default_download_path, should_uniquify_path, |
| 633 callback); | 608 callback); |
| 634 } | 609 } |
| 635 | 610 |
| 636 void ChromeDownloadManagerDelegate::CheckDownloadUrlDone( | 611 void ChromeDownloadManagerDelegate::CheckDownloadUrlDone( |
| 637 int32 download_id, | 612 int32 download_id, |
| 638 const content::DownloadTargetCallback& callback, | 613 const content::DownloadTargetCallback& callback, |
| 639 DownloadProtectionService::DownloadCheckResult result) { | 614 DownloadProtectionService::DownloadCheckResult result) { |
| 640 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 615 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 641 DownloadItem* download = | 616 DownloadItem* download = download_manager_->GetDownload(download_id); |
| 642 download_manager_->GetActiveDownloadItem(download_id); | 617 if (!download || (download->GetState() != DownloadItem::IN_PROGRESS)) |
| 643 if (!download) | |
| 644 return; | 618 return; |
| 645 | 619 |
| 646 VLOG(2) << __FUNCTION__ << "() download = " << download->DebugString(false) | 620 VLOG(2) << __FUNCTION__ << "() download = " << download->DebugString(false) |
| 647 << " verdict = " << result; | 621 << " verdict = " << result; |
| 648 content::DownloadDangerType danger_type = download->GetDangerType(); | 622 content::DownloadDangerType danger_type = download->GetDangerType(); |
| 649 if (result != DownloadProtectionService::SAFE) | 623 if (result != DownloadProtectionService::SAFE) |
| 650 danger_type = content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL; | 624 danger_type = content::DOWNLOAD_DANGER_TYPE_DANGEROUS_URL; |
| 651 | 625 |
| 652 download_history_->CheckVisitedReferrerBefore( | 626 DownloadHistory* history = download_history_.get(); |
| 653 download_id, download->GetReferrerUrl(), | 627 if (!history && profile_->IsOffTheRecord()) { |
| 654 base::Bind(&ChromeDownloadManagerDelegate::CheckVisitedReferrerBeforeDone, | 628 // If there's no DownloadHistory because this profile IsOffTheRecord, then |
| 655 this, download_id, callback, danger_type)); | 629 // go to the original profile and ask its ChromeDownloadManagerDelegate to |
| 630 // check the on-record visited db. | |
| 631 history = DownloadServiceFactory::GetForProfile( | |
| 632 profile_->GetOriginalProfile())->GetDownloadManagerDelegate() | |
| 633 ->download_history_.get(); | |
| 634 } | |
| 635 if (history) { | |
| 636 history->CheckVisitedReferrerBefore( | |
| 637 download->GetReferrerUrl(), base::Bind( | |
| 638 &ChromeDownloadManagerDelegate::CheckVisitedReferrerBeforeDone, | |
| 639 this, download_id, callback, danger_type)); | |
| 640 return; | |
| 641 } | |
| 642 // If there's no history but the profile is on-record, or if this profile is | |
|
Randy Smith (Not in Mondays)
2012/09/24 18:03:25
Are there any cases in which we're on-record and h
benjhayden
2012/11/02 17:21:37
My understanding is that there is some rare case w
Randy Smith (Not in Mondays)
2012/11/02 23:31:24
Cool, thanks.
WRT the couple of branches & fall-
benjhayden
2012/11/06 20:01:14
The DCHECK exploded in unit_tests: ChromeDownloadM
| |
| 643 // off-record and the original profile doesn't have a DownloadHistory, then | |
| 644 // give up and assume the referrer has not been visited before. | |
| 645 CheckVisitedReferrerBeforeDone(download_id, callback, danger_type, false); | |
|
Randy Smith (Not in Mondays)
2012/09/24 18:03:25
nit, suggestion: I have a slight preference for th
benjhayden
2012/11/02 17:21:37
Done.
| |
| 656 } | 646 } |
| 657 | 647 |
| 658 void ChromeDownloadManagerDelegate::CheckClientDownloadDone( | 648 void ChromeDownloadManagerDelegate::CheckClientDownloadDone( |
| 659 int32 download_id, | 649 int32 download_id, |
| 660 DownloadProtectionService::DownloadCheckResult result) { | 650 DownloadProtectionService::DownloadCheckResult result) { |
| 661 DownloadItem* item = download_manager_->GetActiveDownloadItem(download_id); | 651 DownloadItem* item = download_manager_->GetActiveDownloadItem(download_id); |
| 662 if (!item) | 652 if (!item) |
| 663 return; | 653 return; |
| 664 | 654 |
| 665 VLOG(2) << __FUNCTION__ << "() download = " << item->DebugString(false) | 655 VLOG(2) << __FUNCTION__ << "() download = " << item->DebugString(false) |
| (...skipping 224 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 890 // TODO(asanka): This logic is a hack. DownloadFilePicker should give us a | 880 // TODO(asanka): This logic is a hack. DownloadFilePicker should give us a |
| 891 // directory to persist. Or perhaps, if the Drive path | 881 // directory to persist. Or perhaps, if the Drive path |
| 892 // substitution logic is moved here, then we would have a | 882 // substitution logic is moved here, then we would have a |
| 893 // persistable path after the DownloadFilePicker is done. | 883 // persistable path after the DownloadFilePicker is done. |
| 894 if (disposition == DownloadItem::TARGET_DISPOSITION_PROMPT && | 884 if (disposition == DownloadItem::TARGET_DISPOSITION_PROMPT && |
| 895 !download->IsTemporary()) | 885 !download->IsTemporary()) |
| 896 last_download_path_ = target_path.DirName(); | 886 last_download_path_ = target_path.DirName(); |
| 897 } | 887 } |
| 898 callback.Run(target_path, disposition, danger_type, intermediate_path); | 888 callback.Run(target_path, disposition, danger_type, intermediate_path); |
| 899 } | 889 } |
| 900 | |
| 901 void ChromeDownloadManagerDelegate::OnItemAddedToPersistentStore( | |
| 902 int32 download_id, int64 db_handle) { | |
| 903 // It's not immediately obvious, but HistoryBackend::CreateDownload() can | |
| 904 // call this function with an invalid |db_handle|. For instance, this can | |
| 905 // happen when the history database is offline. We cannot have multiple | |
| 906 // DownloadItems with the same invalid db_handle, so we need to assign a | |
| 907 // unique |db_handle| here. | |
| 908 if (db_handle == DownloadItem::kUninitializedHandle) | |
| 909 db_handle = download_history_->GetNextFakeDbHandle(); | |
| 910 download_manager_->OnItemAddedToPersistentStore(download_id, db_handle); | |
| 911 } | |
| OLD | NEW |