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 3 // found in the LICENSE file. 4 // 5 // Each download is represented by a DownloadItem, and all DownloadItems 6 // are owned by the DownloadManager which maintains a global list of all 7 // downloads. DownloadItems are created when a user initiates a download, 8 // and exist for the duration of the browser life time. 9 // 10 // Download observers: 11 // DownloadItem::Observer: 12 // - allows observers to receive notifications about one download from start 13 // to completion 14 // Use AddObserver() / RemoveObserver() on the appropriate download object to 15 // receive state updates. 16 17 #ifndef CONTENT_PUBLIC_BROWSER_DOWNLOAD_ITEM_H_ 18 #define CONTENT_PUBLIC_BROWSER_DOWNLOAD_ITEM_H_ 19 20 #include <map> 21 #include <string> 22 #include <vector> 23 24 #include "base/callback_forward.h" 25 #include "base/files/file_path.h" 26 #include "base/strings/string16.h" 27 #include "base/supports_user_data.h" 28 #include "content/public/browser/download_danger_type.h" 29 #include "content/public/browser/download_interrupt_reasons.h" 30 #include "content/public/common/page_transition_types.h" 31 32 class GURL; 33 34 namespace base { 35 class FilePath; 36 class Time; 37 class TimeDelta; 38 } 39 40 namespace content { 41 42 class BrowserContext; 43 class DownloadManager; 44 class WebContents; 45 46 // One DownloadItem per download. This is the model class that stores all the 47 // state for a download. Multiple views, such as a tab's download shelf and the 48 // Destination tab's download view, may refer to a given DownloadItem. 49 // 50 // This is intended to be used only on the UI thread. 51 class CONTENT_EXPORT DownloadItem : public base::SupportsUserData { 52 public: 53 enum DownloadState { 54 // Download is actively progressing. 55 IN_PROGRESS = 0, 56 57 // Download is completely finished. 58 COMPLETE, 59 60 // Download has been cancelled. 61 CANCELLED, 62 63 // This state indicates that the download has been interrupted. 64 INTERRUPTED, 65 66 // Maximum value. 67 MAX_DOWNLOAD_STATE 68 }; 69 70 // How the final target path should be used. 71 enum TargetDisposition { 72 TARGET_DISPOSITION_OVERWRITE, // Overwrite if the target already exists. 73 TARGET_DISPOSITION_PROMPT // Prompt the user for the actual 74 // target. Implies 75 // TARGET_DISPOSITION_OVERWRITE. 76 }; 77 78 // Callback used with AcquireFileAndDeleteDownload(). 79 typedef base::Callback<void(const base::FilePath&)> AcquireFileCallback; 80 81 static const uint32 kInvalidId; 82 83 static const char kEmptyFileHash[]; 84 85 // Interface that observers of a particular download must implement in order 86 // to receive updates to the download's status. 87 class CONTENT_EXPORT Observer { 88 public: OnDownloadUpdated(DownloadItem * download)89 virtual void OnDownloadUpdated(DownloadItem* download) {} OnDownloadOpened(DownloadItem * download)90 virtual void OnDownloadOpened(DownloadItem* download) {} OnDownloadRemoved(DownloadItem * download)91 virtual void OnDownloadRemoved(DownloadItem* download) {} 92 93 // Called when the download is being destroyed. This happens after 94 // every OnDownloadRemoved() as well as when the DownloadManager is going 95 // down. OnDownloadDestroyed(DownloadItem * download)96 virtual void OnDownloadDestroyed(DownloadItem* download) {} 97 98 protected: ~Observer()99 virtual ~Observer() {} 100 }; 101 ~DownloadItem()102 virtual ~DownloadItem() {} 103 104 // Observation --------------------------------------------------------------- 105 106 virtual void AddObserver(DownloadItem::Observer* observer) = 0; 107 virtual void RemoveObserver(DownloadItem::Observer* observer) = 0; 108 virtual void UpdateObservers() = 0; 109 110 // User Actions -------------------------------------------------------------- 111 112 // Called when the user has validated the download of a dangerous file. 113 virtual void ValidateDangerousDownload() = 0; 114 115 // Called to acquire a dangerous download and remove the DownloadItem from 116 // views and history. |callback| will be invoked on the UI thread with the 117 // path to the downloaded file. The caller is responsible for cleanup. 118 // Note: It is important for |callback| to be valid since the downloaded file 119 // will not be cleaned up if the callback fails. 120 virtual void StealDangerousDownload(const AcquireFileCallback& callback) = 0; 121 122 // Pause a download. Will have no effect if the download is already 123 // paused. 124 virtual void Pause() = 0; 125 126 // Resume a download that has been paused or interrupted. Will have no effect 127 // if the download is neither. 128 virtual void Resume() = 0; 129 130 // Cancel the download operation. We need to distinguish between cancels at 131 // exit (DownloadManager destructor) from user interface initiated cancels 132 // because at exit, the history system may not exist, and any updates to it 133 // require AddRef'ing the DownloadManager in the destructor which results in 134 // a DCHECK failure. Set |user_cancel| to false when canceling from at 135 // exit to prevent this crash. This may result in a difference between the 136 // downloaded file's size on disk, and what the history system's last record 137 // of it is. At worst, we'll end up re-downloading a small portion of the file 138 // when resuming a download (assuming the server supports byte ranges). 139 virtual void Cancel(bool user_cancel) = 0; 140 141 // Removes the download from the views and history. If the download was 142 // in-progress or interrupted, then the intermediate file will also be 143 // deleted. 144 virtual void Remove() = 0; 145 146 // Open the file associated with this download. If the download is 147 // still in progress, marks the download to be opened when it is complete. 148 virtual void OpenDownload() = 0; 149 150 // Show the download via the OS shell. 151 virtual void ShowDownloadInShell() = 0; 152 153 // State accessors ----------------------------------------------------------- 154 155 virtual uint32 GetId() const = 0; 156 virtual DownloadState GetState() const = 0; 157 158 // Returns the most recent interrupt reason for this download. Returns 159 // DOWNLOAD_INTERRUPT_REASON_NONE if there is no previous interrupt reason. 160 // Cancelled downloads return DOWNLOAD_INTERRUPT_REASON_USER_CANCELLED. If 161 // the download was resumed, then the return value is the interrupt reason 162 // prior to resumption. 163 virtual DownloadInterruptReason GetLastReason() const = 0; 164 165 virtual bool IsPaused() const = 0; 166 virtual bool IsTemporary() const = 0; 167 168 // Returns true if the download can be resumed. A download can be resumed if 169 // an in-progress download was paused or if an interrupted download requires 170 // user-interaction to resume. 171 virtual bool CanResume() const = 0; 172 173 // Returns true if the download is in a terminal state. This includes 174 // completed downloads, cancelled downloads, and interrupted downloads that 175 // can't be resumed. 176 virtual bool IsDone() const = 0; 177 178 // Origin State accessors ------------------------------------------------- 179 180 virtual const GURL& GetURL() const = 0; 181 virtual const std::vector<GURL>& GetUrlChain() const = 0; 182 virtual const GURL& GetOriginalUrl() const = 0; 183 virtual const GURL& GetReferrerUrl() const = 0; 184 virtual const GURL& GetTabUrl() const = 0; 185 virtual const GURL& GetTabReferrerUrl() const = 0; 186 virtual std::string GetSuggestedFilename() const = 0; 187 virtual std::string GetContentDisposition() const = 0; 188 virtual std::string GetMimeType() const = 0; 189 virtual std::string GetOriginalMimeType() const = 0; 190 virtual std::string GetRemoteAddress() const = 0; 191 virtual bool HasUserGesture() const = 0; 192 virtual PageTransition GetTransitionType() const = 0; 193 virtual const std::string& GetLastModifiedTime() const = 0; 194 virtual const std::string& GetETag() const = 0; 195 virtual bool IsSavePackageDownload() const = 0; 196 197 // Destination State accessors -------------------------------------------- 198 199 // Full path to the downloaded or downloading file. This is the path to the 200 // physical file, if one exists. It should be considered a hint; changes to 201 // this value and renames of the file on disk are not atomic with each other. 202 // May be empty if the in-progress path hasn't been determined yet or if the 203 // download was interrupted. 204 // 205 // DO NOT USE THIS METHOD to access the target path of the DownloadItem. Use 206 // GetTargetFilePath() instead. While the download is in progress, the 207 // intermediate file named by GetFullPath() may be renamed or disappear 208 // completely on the FILE thread. The path may also be reset to empty when the 209 // download is interrupted. 210 virtual const base::FilePath& GetFullPath() const = 0; 211 212 // Target path of an in-progress download. We may be downloading to a 213 // temporary or intermediate file (specified by GetFullPath()); this is the 214 // name we will use once the download completes. 215 // May be empty if the target path hasn't yet been determined. 216 virtual const base::FilePath& GetTargetFilePath() const = 0; 217 218 // If the download forced a path rather than requesting name determination, 219 // return the path requested. 220 virtual const base::FilePath& GetForcedFilePath() const = 0; 221 222 // Returns the file-name that should be reported to the user. If a display 223 // name has been explicitly set using SetDisplayName(), this function returns 224 // that display name. Otherwise returns the final target filename. 225 virtual base::FilePath GetFileNameToReportUser() const = 0; 226 227 virtual TargetDisposition GetTargetDisposition() const = 0; 228 229 // Final hash of completely downloaded file; not valid if 230 // GetState() != COMPLETED. 231 virtual const std::string& GetHash() const = 0; 232 233 // Intermediate hash state, for persisting partial downloads. 234 virtual const std::string& GetHashState() const = 0; 235 236 // True if the file associated with the download has been removed by 237 // external action. 238 virtual bool GetFileExternallyRemoved() const = 0; 239 240 // If the file is successfully deleted, then GetFileExternallyRemoved() will 241 // become true, GetFullPath() will become empty, and 242 // DownloadItem::OnDownloadUpdated() will be called. Does nothing if 243 // GetState() == COMPLETE or GetFileExternallyRemoved() is already true or 244 // GetFullPath() is already empty. The callback is always run, and it is 245 // always run asynchronously. It will be passed true if the file is 246 // successfully deleted or if GetFilePath() was already empty or if 247 // GetFileExternallyRemoved() was already true. The callback will be passed 248 // false if the DownloadItem was not yet complete or if the file could not be 249 // deleted for any reason. 250 virtual void DeleteFile(const base::Callback<void(bool)>& callback) = 0; 251 252 // True if the file that will be written by the download is dangerous 253 // and we will require a call to ValidateDangerousDownload() to complete. 254 // False if the download is safe or that function has been called. 255 virtual bool IsDangerous() const = 0; 256 257 // Why |safety_state_| is not SAFE. 258 virtual DownloadDangerType GetDangerType() const = 0; 259 260 // Progress State accessors ----------------------------------------------- 261 262 // Simple calculation of the amount of time remaining to completion. Fills 263 // |*remaining| with the amount of time remaining if successful. Fails and 264 // returns false if we do not have the number of bytes or the speed so can 265 // not estimate. 266 virtual bool TimeRemaining(base::TimeDelta* remaining) const = 0; 267 268 // Simple speed estimate in bytes/s 269 virtual int64 CurrentSpeed() const = 0; 270 271 // Rough percent complete, -1 means we don't know (== we didn't receive a 272 // total size). 273 virtual int PercentComplete() const = 0; 274 275 // Returns true if this download has saved all of its data. 276 virtual bool AllDataSaved() const = 0; 277 278 virtual int64 GetTotalBytes() const = 0; 279 virtual int64 GetReceivedBytes() const = 0; 280 virtual base::Time GetStartTime() const = 0; 281 virtual base::Time GetEndTime() const = 0; 282 283 // Open/Show State accessors ---------------------------------------------- 284 285 // Returns true if it is OK to open a folder which this file is inside. 286 virtual bool CanShowInFolder() = 0; 287 288 // Returns true if it is OK to open the download. 289 virtual bool CanOpenDownload() = 0; 290 291 // Tests if a file type should be opened automatically. 292 virtual bool ShouldOpenFileBasedOnExtension() = 0; 293 294 // Returns true if the download will be auto-opened when complete. 295 virtual bool GetOpenWhenComplete() const = 0; 296 297 // Returns true if the download has been auto-opened by the system. 298 virtual bool GetAutoOpened() = 0; 299 300 // Returns true if the download has been opened. 301 virtual bool GetOpened() const = 0; 302 303 // Misc State accessors --------------------------------------------------- 304 305 virtual BrowserContext* GetBrowserContext() const = 0; 306 virtual WebContents* GetWebContents() const = 0; 307 308 // External state transitions/setters ---------------------------------------- 309 // TODO(rdsmith): These should all be removed; the download item should 310 // control its own state transitions. 311 312 // Called if a check of the download contents was performed and the results of 313 // the test are available. This should only be called after AllDataSaved() is 314 // true. 315 virtual void OnContentCheckCompleted(DownloadDangerType danger_type) = 0; 316 317 // Mark the download to be auto-opened when completed. 318 virtual void SetOpenWhenComplete(bool open) = 0; 319 320 // Mark the download as temporary (not visible in persisted store or 321 // SearchDownloads(), removed from main UI upon completion). 322 virtual void SetIsTemporary(bool temporary) = 0; 323 324 // Mark the download as having been opened (without actually opening it). 325 virtual void SetOpened(bool opened) = 0; 326 327 // Set a display name for the download that will be independent of the target 328 // filename. If |name| is not empty, then GetFileNameToReportUser() will 329 // return |name|. Has no effect on the final target filename. 330 virtual void SetDisplayName(const base::FilePath& name) = 0; 331 332 // Debug/testing ------------------------------------------------------------- 333 virtual std::string DebugString(bool verbose) const = 0; 334 }; 335 336 } // namespace content 337 338 #endif // CONTENT_PUBLIC_BROWSER_DOWNLOAD_ITEM_H_ 339