| 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 #ifndef CHROME_BROWSER_DOWNLOAD_CHROME_DOWNLOAD_MANAGER_DELEGATE_H_ | 5 #ifndef CHROME_BROWSER_DOWNLOAD_CHROME_DOWNLOAD_MANAGER_DELEGATE_H_ |
| 6 #define CHROME_BROWSER_DOWNLOAD_CHROME_DOWNLOAD_MANAGER_DELEGATE_H_ | 6 #define CHROME_BROWSER_DOWNLOAD_CHROME_DOWNLOAD_MANAGER_DELEGATE_H_ |
| 7 | 7 |
| 8 #include "base/compiler_specific.h" | 8 #include "base/compiler_specific.h" |
| 9 #include "base/hash_tables.h" | 9 #include "base/hash_tables.h" |
| 10 #include "base/memory/ref_counted.h" | 10 #include "base/memory/ref_counted.h" |
| (...skipping 30 matching lines...) Expand all Loading... |
| 41 }; | 41 }; |
| 42 } // namespace BASE_HASH_NAMESPACE | 42 } // namespace BASE_HASH_NAMESPACE |
| 43 #endif | 43 #endif |
| 44 | 44 |
| 45 // This is the Chrome side helper for the download system. | 45 // This is the Chrome side helper for the download system. |
| 46 class ChromeDownloadManagerDelegate | 46 class ChromeDownloadManagerDelegate |
| 47 : public base::RefCountedThreadSafe<ChromeDownloadManagerDelegate>, | 47 : public base::RefCountedThreadSafe<ChromeDownloadManagerDelegate>, |
| 48 public content::DownloadManagerDelegate, | 48 public content::DownloadManagerDelegate, |
| 49 public content::NotificationObserver { | 49 public content::NotificationObserver { |
| 50 public: | 50 public: |
| 51 // Callback type used with ChooseDownloadPath(). The callback should be |
| 52 // invoked with the user-selected path as the argument. If the file selection |
| 53 // was canceled, the argument should be the empty path. |
| 54 typedef base::Callback<void(const FilePath&)> FileSelectedCallback; |
| 55 |
| 51 explicit ChromeDownloadManagerDelegate(Profile* profile); | 56 explicit ChromeDownloadManagerDelegate(Profile* profile); |
| 52 | 57 |
| 53 void SetDownloadManager(content::DownloadManager* dm); | 58 void SetDownloadManager(content::DownloadManager* dm); |
| 54 | 59 |
| 55 // Should be called before the first call to ShouldCompleteDownload() to | 60 // Should be called before the first call to ShouldCompleteDownload() to |
| 56 // disable SafeBrowsing checks for |item|. | 61 // disable SafeBrowsing checks for |item|. |
| 57 static void DisableSafeBrowsing(content::DownloadItem* item); | 62 static void DisableSafeBrowsing(content::DownloadItem* item); |
| 58 | 63 |
| 64 // content::DownloadManagerDelegate |
| 59 virtual void Shutdown() OVERRIDE; | 65 virtual void Shutdown() OVERRIDE; |
| 60 virtual content::DownloadId GetNextId() OVERRIDE; | 66 virtual content::DownloadId GetNextId() OVERRIDE; |
| 61 virtual bool ShouldStartDownload(int32 download_id) OVERRIDE; | 67 virtual bool DetermineDownloadTarget( |
| 62 virtual void ChooseDownloadPath(content::DownloadItem* item) OVERRIDE; | 68 content::DownloadItem* item, |
| 63 virtual FilePath GetIntermediatePath( | 69 const content::DownloadTargetCallback& callback) OVERRIDE; |
| 64 const content::DownloadItem& item) OVERRIDE; | |
| 65 virtual content::WebContents* | 70 virtual content::WebContents* |
| 66 GetAlternativeWebContentsToNotifyForDownload() OVERRIDE; | 71 GetAlternativeWebContentsToNotifyForDownload() OVERRIDE; |
| 67 virtual bool ShouldOpenFileBasedOnExtension(const FilePath& path) OVERRIDE; | 72 virtual bool ShouldOpenFileBasedOnExtension(const FilePath& path) OVERRIDE; |
| 68 virtual bool ShouldCompleteDownload( | 73 virtual bool ShouldCompleteDownload( |
| 69 content::DownloadItem* item, | 74 content::DownloadItem* item, |
| 70 const base::Closure& complete_callback) OVERRIDE; | 75 const base::Closure& complete_callback) OVERRIDE; |
| 71 virtual bool ShouldOpenDownload(content::DownloadItem* item) OVERRIDE; | 76 virtual bool ShouldOpenDownload(content::DownloadItem* item) OVERRIDE; |
| 72 virtual bool GenerateFileHash() OVERRIDE; | 77 virtual bool GenerateFileHash() OVERRIDE; |
| 73 virtual void AddItemToPersistentStore(content::DownloadItem* item) OVERRIDE; | 78 virtual void AddItemToPersistentStore(content::DownloadItem* item) OVERRIDE; |
| 74 virtual void UpdateItemInPersistentStore( | 79 virtual void UpdateItemInPersistentStore( |
| (...skipping 10 matching lines...) Expand all Loading... |
| 85 FilePath* website_save_dir, | 90 FilePath* website_save_dir, |
| 86 FilePath* download_save_dir, | 91 FilePath* download_save_dir, |
| 87 bool* skip_dir_check) OVERRIDE; | 92 bool* skip_dir_check) OVERRIDE; |
| 88 virtual void ChooseSavePath( | 93 virtual void ChooseSavePath( |
| 89 content::WebContents* web_contents, | 94 content::WebContents* web_contents, |
| 90 const FilePath& suggested_path, | 95 const FilePath& suggested_path, |
| 91 const FilePath::StringType& default_extension, | 96 const FilePath::StringType& default_extension, |
| 92 bool can_save_as_complete, | 97 bool can_save_as_complete, |
| 93 const content::SavePackagePathPickedCallback& callback) OVERRIDE; | 98 const content::SavePackagePathPickedCallback& callback) OVERRIDE; |
| 94 | 99 |
| 100 // Clears the last directory chosen by the user in response to a file chooser |
| 101 // prompt. Called when clearing recent history. |
| 102 void ClearLastDownloadPath(); |
| 103 |
| 95 DownloadPrefs* download_prefs() { return download_prefs_.get(); } | 104 DownloadPrefs* download_prefs() { return download_prefs_.get(); } |
| 96 DownloadHistory* download_history() { return download_history_.get(); } | 105 DownloadHistory* download_history() { return download_history_.get(); } |
| 97 | 106 |
| 98 protected: | 107 protected: |
| 99 // So that test classes can inherit from this for override purposes. | 108 // So that test classes can inherit from this for override purposes. |
| 100 virtual ~ChromeDownloadManagerDelegate(); | 109 virtual ~ChromeDownloadManagerDelegate(); |
| 101 | 110 |
| 102 // Returns the SafeBrowsing download protection service if it's | 111 // Returns the SafeBrowsing download protection service if it's |
| 103 // enabled. Returns NULL otherwise. Protected virtual for testing. | 112 // enabled. Returns NULL otherwise. Protected virtual for testing. |
| 104 virtual safe_browsing::DownloadProtectionService* | 113 virtual safe_browsing::DownloadProtectionService* |
| 105 GetDownloadProtectionService(); | 114 GetDownloadProtectionService(); |
| 106 | 115 |
| 107 // Returns true if this download should show the "dangerous file" warning. | 116 // Returns true if this download should show the "dangerous file" warning. |
| 108 // Various factors are considered, such as the type of the file, whether a | 117 // Various factors are considered, such as the type of the file, whether a |
| 109 // user action initiated the download, and whether the user has explicitly | 118 // user action initiated the download, and whether the user has explicitly |
| 110 // marked the file type as "auto open". Protected virtual for testing. | 119 // marked the file type as "auto open". Protected virtual for testing. |
| 111 virtual bool IsDangerousFile(const content::DownloadItem& download, | 120 virtual bool IsDangerousFile(const content::DownloadItem& download, |
| 112 const FilePath& suggested_path, | 121 const FilePath& suggested_path, |
| 113 bool visited_referrer_before); | 122 bool visited_referrer_before); |
| 114 | 123 |
| 115 // Obtains a path reservation by calling | 124 // Obtains a path reservation by calling |
| 116 // DownloadPathReservationTracker::GetReservedPath(). Protected virtual for | 125 // DownloadPathReservationTracker::GetReservedPath(). Protected virtual for |
| 117 // testing. | 126 // testing. |
| 118 virtual void GetReservedPath( | 127 virtual void GetReservedPath( |
| 119 content::DownloadItem& download, | 128 content::DownloadItem& download, |
| 120 const FilePath& target_path, | 129 const FilePath& target_path, |
| 121 const FilePath& default_download_path, | 130 const FilePath& default_download_path, |
| 122 bool should_uniquify_path, | 131 bool should_uniquify_path, |
| 123 const DownloadPathReservationTracker::ReservedPathCallback callback); | 132 const DownloadPathReservationTracker::ReservedPathCallback& callback); |
| 133 |
| 134 // Displays the file chooser dialog to prompt the user for the download |
| 135 // location for |item|. |suggested_path| will be used as the initial download |
| 136 // path. Once a location is available |callback| will be invoked with the |
| 137 // selected full path. If the user cancels the dialog, then an empty FilePath |
| 138 // will be passed into |callback|. Protected virtual for testing. |
| 139 virtual void ChooseDownloadPath(content::DownloadItem* item, |
| 140 const FilePath& suggested_path, |
| 141 const FileSelectedCallback& callback); |
| 124 | 142 |
| 125 // So that test classes that inherit from this for override purposes | 143 // So that test classes that inherit from this for override purposes |
| 126 // can call back into the DownloadManager. | 144 // can call back into the DownloadManager. |
| 127 scoped_refptr<content::DownloadManager> download_manager_; | 145 scoped_refptr<content::DownloadManager> download_manager_; |
| 128 | 146 |
| 129 private: | 147 private: |
| 130 friend class base::RefCountedThreadSafe<ChromeDownloadManagerDelegate>; | 148 friend class base::RefCountedThreadSafe<ChromeDownloadManagerDelegate>; |
| 131 | 149 |
| 132 // content::NotificationObserver implementation. | 150 // content::NotificationObserver implementation. |
| 133 virtual void Observe(int type, | 151 virtual void Observe(int type, |
| 134 const content::NotificationSource& source, | 152 const content::NotificationSource& source, |
| 135 const content::NotificationDetails& details) OVERRIDE; | 153 const content::NotificationDetails& details) OVERRIDE; |
| 136 | 154 |
| 137 // Callback function after url is checked with safebrowsing service. | 155 // Callback function after url is checked with safebrowsing service. |
| 138 void CheckDownloadUrlDone( | 156 void CheckDownloadUrlDone( |
| 139 int32 download_id, | 157 int32 download_id, |
| 158 const content::DownloadTargetCallback& callback, |
| 140 safe_browsing::DownloadProtectionService::DownloadCheckResult result); | 159 safe_browsing::DownloadProtectionService::DownloadCheckResult result); |
| 141 | 160 |
| 142 // Callback function after the DownloadProtectionService completes. | 161 // Callback function after the DownloadProtectionService completes. |
| 143 void CheckClientDownloadDone( | 162 void CheckClientDownloadDone( |
| 144 int32 download_id, | 163 int32 download_id, |
| 145 safe_browsing::DownloadProtectionService::DownloadCheckResult result); | 164 safe_browsing::DownloadProtectionService::DownloadCheckResult result); |
| 146 | 165 |
| 147 // Callback function after we check whether the referrer URL has been visited | 166 // Callback function after we check whether the referrer URL has been visited |
| 148 // before today. Determines the danger state of the download based on the file | 167 // before today. Determines the danger state of the download based on the file |
| 149 // type and |visited_referrer_before|. Generates a target path for the | 168 // type and |visited_referrer_before|. Generates a target path for the |
| 150 // download. Invokes |DownloadPathReservationTracker::GetReservedPath| to get | 169 // download. Invokes |DownloadPathReservationTracker::GetReservedPath| to get |
| 151 // a reserved path for the download. The path is then passed into | 170 // a reserved path for the download. The path is then passed into |
| 152 // OnPathReservationAvailable(). | 171 // OnPathReservationAvailable(). |
| 153 void CheckVisitedReferrerBeforeDone(int32 download_id, | 172 void CheckVisitedReferrerBeforeDone( |
| 154 content::DownloadDangerType danger_type, | 173 int32 download_id, |
| 155 bool visited_referrer_before); | 174 const content::DownloadTargetCallback& callback, |
| 175 content::DownloadDangerType danger_type, |
| 176 bool visited_referrer_before); |
| 156 | 177 |
| 157 #if defined (OS_CHROMEOS) | 178 #if defined (OS_CHROMEOS) |
| 158 // GDataDownloadObserver::SubstituteGDataDownloadPath callback. Calls | 179 // GDataDownloadObserver::SubstituteGDataDownloadPath callback. Calls |
| 159 // |DownloadPathReservationTracker::GetReservedPath| to get a reserved path | 180 // |DownloadPathReservationTracker::GetReservedPath| to get a reserved path |
| 160 // for the download. The path is then passed into | 181 // for the download. The path is then passed into |
| 161 // OnPathReservationAvailable(). | 182 // OnPathReservationAvailable(). |
| 162 void SubstituteGDataDownloadPathCallback( | 183 void SubstituteGDataDownloadPathCallback( |
| 163 int32 download_id, | 184 int32 download_id, |
| 185 const content::DownloadTargetCallback& callback, |
| 164 bool should_prompt, | 186 bool should_prompt, |
| 165 bool is_forced_path, | 187 bool is_forced_path, |
| 166 content::DownloadDangerType danger_type, | 188 content::DownloadDangerType danger_type, |
| 167 const FilePath& unverified_path); | 189 const FilePath& unverified_path); |
| 168 #endif | 190 #endif |
| 169 | 191 |
| 192 // Determine the intermediate path to use for |target_path|. |danger_type| |
| 193 // specifies the danger level of the download. |
| 194 FilePath GetIntermediatePath(const FilePath& target_path, |
| 195 content::DownloadDangerType danger_type); |
| 196 |
| 170 // Called on the UI thread once a reserved path is available. Updates the | 197 // Called on the UI thread once a reserved path is available. Updates the |
| 171 // download identified by |download_id| with the |target_path|, target | 198 // download identified by |download_id| with the |target_path|, target |
| 172 // disposition and |danger_type|. | 199 // disposition and |danger_type|. |
| 173 void OnPathReservationAvailable( | 200 void OnPathReservationAvailable( |
| 174 int32 download_id, | 201 int32 download_id, |
| 202 const content::DownloadTargetCallback& callback, |
| 175 bool should_prompt, | 203 bool should_prompt, |
| 176 content::DownloadDangerType danger_type, | 204 content::DownloadDangerType danger_type, |
| 177 const FilePath& target_path, | 205 const FilePath& reserved_path, |
| 178 bool target_path_verified); | 206 bool reserved_path_verified); |
| 207 |
| 208 // Called on the UI thread once the final target path is available. |
| 209 void OnTargetPathDetermined( |
| 210 int32 download_id, |
| 211 const content::DownloadTargetCallback& callback, |
| 212 content::DownloadItem::TargetDisposition disposition, |
| 213 content::DownloadDangerType danger_type, |
| 214 const FilePath& target_path); |
| 179 | 215 |
| 180 // Callback from history system. | 216 // Callback from history system. |
| 181 void OnItemAddedToPersistentStore(int32 download_id, int64 db_handle); | 217 void OnItemAddedToPersistentStore(int32 download_id, int64 db_handle); |
| 182 | 218 |
| 183 // Check policy of whether we should open this download with a web intents | 219 // Check policy of whether we should open this download with a web intents |
| 184 // dispatch. | 220 // dispatch. |
| 185 bool ShouldOpenWithWebIntents(const content::DownloadItem* item); | 221 bool ShouldOpenWithWebIntents(const content::DownloadItem* item); |
| 186 | 222 |
| 187 // Open the given item with a web intent dispatch. | 223 // Open the given item with a web intent dispatch. |
| 188 void OpenWithWebIntent(const content::DownloadItem* item); | 224 void OpenWithWebIntent(const content::DownloadItem* item); |
| (...skipping 24 matching lines...) Expand all Loading... |
| 213 #if !defined(OS_ANDROID) | 249 #if !defined(OS_ANDROID) |
| 214 // The ExtensionDownloadsEventRouter dispatches download creation, change, and | 250 // The ExtensionDownloadsEventRouter dispatches download creation, change, and |
| 215 // erase events to extensions. Like ChromeDownloadManagerDelegate, it's a | 251 // erase events to extensions. Like ChromeDownloadManagerDelegate, it's a |
| 216 // chrome-level concept and its lifetime should match DownloadManager. There | 252 // chrome-level concept and its lifetime should match DownloadManager. There |
| 217 // should be a separate EDER for on-record and off-record managers. | 253 // should be a separate EDER for on-record and off-record managers. |
| 218 // There does not appear to be a separate ExtensionSystem for on-record and | 254 // There does not appear to be a separate ExtensionSystem for on-record and |
| 219 // off-record profiles, so ExtensionSystem cannot own the EDER. | 255 // off-record profiles, so ExtensionSystem cannot own the EDER. |
| 220 scoped_ptr<ExtensionDownloadsEventRouter> extension_event_router_; | 256 scoped_ptr<ExtensionDownloadsEventRouter> extension_event_router_; |
| 221 #endif | 257 #endif |
| 222 | 258 |
| 259 // The directory most recently chosen by the user in response to a Save As |
| 260 // dialog for a regular download. |
| 261 FilePath last_download_path_; |
| 262 |
| 223 DISALLOW_COPY_AND_ASSIGN(ChromeDownloadManagerDelegate); | 263 DISALLOW_COPY_AND_ASSIGN(ChromeDownloadManagerDelegate); |
| 224 }; | 264 }; |
| 225 | 265 |
| 226 #endif // CHROME_BROWSER_DOWNLOAD_CHROME_DOWNLOAD_MANAGER_DELEGATE_H_ | 266 #endif // CHROME_BROWSER_DOWNLOAD_CHROME_DOWNLOAD_MANAGER_DELEGATE_H_ |
| OLD | NEW |