| // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_MANAGER_IMPL_H_ |
| #define CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_MANAGER_IMPL_H_ |
| |
| #include <stdint.h> |
| |
| #include <memory> |
| #include <set> |
| #include <string> |
| #include <unordered_map> |
| #include <vector> |
| |
| #include "base/callback_forward.h" |
| #include "base/macros.h" |
| #include "base/memory/ref_counted.h" |
| #include "base/memory/weak_ptr.h" |
| #include "base/observer_list.h" |
| #include "base/sequenced_task_runner_helpers.h" |
| #include "base/synchronization/lock.h" |
| #include "content/browser/download/download_item_impl_delegate.h" |
| #include "content/browser/download/url_download_handler.h" |
| #include "content/browser/loader/navigation_url_loader.h" |
| #include "content/common/content_export.h" |
| #include "content/public/browser/browser_thread.h" |
| #include "content/public/browser/download_manager.h" |
| #include "content/public/browser/download_manager_delegate.h" |
| #include "content/public/browser/download_url_parameters.h" |
| #include "content/public/browser/ssl_status.h" |
| |
| namespace content { |
| class DownloadFileFactory; |
| class DownloadItemFactory; |
| class DownloadItemImpl; |
| class DownloadRequestHandleInterface; |
| class ResourceContext; |
| |
| class CONTENT_EXPORT DownloadManagerImpl : public DownloadManager, |
| public UrlDownloadHandler::Delegate, |
| private DownloadItemImplDelegate { |
| public: |
| using DownloadItemImplCreated = base::Callback<void(DownloadItemImpl*)>; |
| using UniqueUrlDownloadHandlerPtr = |
| std::unique_ptr<UrlDownloadHandler, BrowserThread::DeleteOnIOThread>; |
| |
| // Caller guarantees that |net_log| will remain valid |
| // for the lifetime of DownloadManagerImpl (until Shutdown() is called). |
| explicit DownloadManagerImpl(BrowserContext* browser_context); |
| ~DownloadManagerImpl() override; |
| |
| // Implementation functions (not part of the DownloadManager interface). |
| |
| // Creates a download item for the SavePackage system. |
| // Must be called on the UI thread. Note that the DownloadManager |
| // retains ownership. |
| virtual void CreateSavePackageDownloadItem( |
| const base::FilePath& main_file_path, |
| const GURL& page_url, |
| const std::string& mime_type, |
| std::unique_ptr<DownloadRequestHandleInterface> request_handle, |
| const DownloadItemImplCreated& item_created); |
| |
| // DownloadManager functions. |
| void SetDelegate(DownloadManagerDelegate* delegate) override; |
| DownloadManagerDelegate* GetDelegate() const override; |
| void Shutdown() override; |
| void GetAllDownloads(DownloadVector* result) override; |
| void StartDownload( |
| std::unique_ptr<DownloadCreateInfo> info, |
| std::unique_ptr<DownloadManager::InputStream> stream, |
| const DownloadUrlParameters::OnStartedCallback& on_started) override; |
| |
| int RemoveDownloadsByURLAndTime( |
| const base::Callback<bool(const GURL&)>& url_filter, |
| base::Time remove_begin, |
| base::Time remove_end) override; |
| void DownloadUrl(std::unique_ptr<DownloadUrlParameters> params) override; |
| void AddObserver(Observer* observer) override; |
| void RemoveObserver(Observer* observer) override; |
| content::DownloadItem* CreateDownloadItem( |
| const std::string& guid, |
| uint32_t id, |
| const base::FilePath& current_path, |
| const base::FilePath& target_path, |
| const std::vector<GURL>& url_chain, |
| const GURL& referrer_url, |
| const GURL& site_url, |
| const GURL& tab_url, |
| const GURL& tab_refererr_url, |
| const std::string& mime_type, |
| const std::string& original_mime_type, |
| base::Time start_time, |
| base::Time end_time, |
| const std::string& etag, |
| const std::string& last_modified, |
| int64_t received_bytes, |
| int64_t total_bytes, |
| const std::string& hash, |
| content::DownloadItem::DownloadState state, |
| DownloadDangerType danger_type, |
| DownloadInterruptReason interrupt_reason, |
| bool opened, |
| base::Time last_access_time, |
| bool transient, |
| const std::vector<DownloadItem::ReceivedSlice>& received_slices) override; |
| void PostInitialization(DownloadInitializationDependency dependency) override; |
| bool IsManagerInitialized() const override; |
| int InProgressCount() const override; |
| int NonMaliciousInProgressCount() const override; |
| BrowserContext* GetBrowserContext() const override; |
| void CheckForHistoryFilesRemoval() override; |
| DownloadItem* GetDownload(uint32_t id) override; |
| DownloadItem* GetDownloadByGuid(const std::string& guid) override; |
| |
| // UrlDownloadHandler::Delegate implementation. |
| void OnUrlDownloadStarted( |
| std::unique_ptr<DownloadCreateInfo> download_create_info, |
| std::unique_ptr<DownloadManager::InputStream> stream, |
| const DownloadUrlParameters::OnStartedCallback& callback) override; |
| void OnUrlDownloadStopped(UrlDownloadHandler* downloader) override; |
| |
| // For testing; specifically, accessed from TestFileErrorInjector. |
| void SetDownloadItemFactoryForTesting( |
| std::unique_ptr<DownloadItemFactory> item_factory); |
| void SetDownloadFileFactoryForTesting( |
| std::unique_ptr<DownloadFileFactory> file_factory); |
| virtual DownloadFileFactory* GetDownloadFileFactoryForTesting(); |
| |
| // Helper function to initiate a download request. This function initiates |
| // the download using functionality provided by the |
| // ResourceDispatcherHostImpl::BeginURLRequest function. The function returns |
| // the result of the downoad operation. Please see the |
| // DownloadInterruptReason enum for information on possible return values. |
| static DownloadInterruptReason BeginDownloadRequest( |
| std::unique_ptr<net::URLRequest> url_request, |
| const Referrer& referrer, |
| ResourceContext* resource_context, |
| bool is_content_initiated, |
| int render_process_id, |
| int render_view_route_id, |
| int render_frame_route_id, |
| bool do_not_prompt_for_login); |
| |
| // Returns the callback to intercept the navigation response. |
| NavigationURLLoader::NavigationInterceptionCB GetNavigationInterceptionCB( |
| const scoped_refptr<ResourceResponse>& response, |
| mojo::ScopedDataPipeConsumerHandle consumer_handle, |
| net::CertStatus cert_status, |
| int frame_tree_node_id); |
| |
| // Checks if a download is allowed, |on_download_allowed_cb| is called if |
| // the download is allowed. |
| void CheckDownloadAllowed( |
| const ResourceRequestInfo::WebContentsGetter& web_contents_getter, |
| const GURL& url, |
| const std::string& request_method, |
| UniqueUrlDownloadHandlerPtr downloader, |
| base::OnceClosure on_download_allowed_cb); |
| |
| private: |
| using DownloadSet = std::set<DownloadItem*>; |
| using DownloadGuidMap = std::unordered_map<std::string, DownloadItemImpl*>; |
| using DownloadItemImplVector = std::vector<DownloadItemImpl*>; |
| |
| // For testing. |
| friend class DownloadManagerTest; |
| friend class DownloadTest; |
| |
| void StartDownloadWithId( |
| std::unique_ptr<DownloadCreateInfo> info, |
| std::unique_ptr<DownloadManager::InputStream> stream, |
| const DownloadUrlParameters::OnStartedCallback& on_started, |
| bool new_download, |
| uint32_t id); |
| |
| void CreateSavePackageDownloadItemWithId( |
| const base::FilePath& main_file_path, |
| const GURL& page_url, |
| const std::string& mime_type, |
| std::unique_ptr<DownloadRequestHandleInterface> request_handle, |
| const DownloadItemImplCreated& on_started, |
| uint32_t id); |
| |
| // Create a new active item based on the info. Separate from |
| // StartDownload() for testing. |
| DownloadItemImpl* CreateActiveItem(uint32_t id, |
| const DownloadCreateInfo& info); |
| |
| // Get next download id. |callback| is called on the UI thread and may |
| // be called synchronously. |
| void GetNextId(const DownloadIdCallback& callback); |
| |
| // Called with the result of DownloadManagerDelegate::CheckForFileExistence. |
| // Updates the state of the file and then notifies this update to the file's |
| // observer. |
| void OnFileExistenceChecked(uint32_t download_id, bool result); |
| |
| // Overridden from DownloadItemImplDelegate |
| // (Note that |GetBrowserContext| are present in both interfaces.) |
| void DetermineDownloadTarget(DownloadItemImpl* item, |
| const DownloadTargetCallback& callback) override; |
| bool ShouldCompleteDownload(DownloadItemImpl* item, |
| const base::Closure& complete_callback) override; |
| bool ShouldOpenFileBasedOnExtension(const base::FilePath& path) override; |
| bool ShouldOpenDownload(DownloadItemImpl* item, |
| const ShouldOpenDownloadCallback& callback) override; |
| void CheckForFileRemoval(DownloadItemImpl* download_item) override; |
| std::string GetApplicationClientIdForFileScanning() const override; |
| void ResumeInterruptedDownload( |
| std::unique_ptr<content::DownloadUrlParameters> params, |
| uint32_t id) override; |
| void OpenDownload(DownloadItemImpl* download) override; |
| void ShowDownloadInShell(DownloadItemImpl* download) override; |
| void DownloadRemoved(DownloadItemImpl* download) override; |
| |
| void AddUrlDownloadHandler(UniqueUrlDownloadHandlerPtr downloader); |
| |
| // Helper method to start or resume a download. |
| void BeginDownloadInternal( |
| std::unique_ptr<content::DownloadUrlParameters> params, |
| uint32_t id); |
| |
| // Called when download permission check is complete. |
| void OnDownloadAllowedCheckComplete(UniqueUrlDownloadHandlerPtr downloader, |
| base::OnceClosure callback, |
| bool allow); |
| |
| // Factory for creation of downloads items. |
| std::unique_ptr<DownloadItemFactory> item_factory_; |
| |
| // Factory for the creation of download files. |
| std::unique_ptr<DownloadFileFactory> file_factory_; |
| |
| // |downloads_| is the owning set for all downloads known to the |
| // DownloadManager. This includes downloads started by the user in |
| // this session, downloads initialized from the history system, and |
| // "save page as" downloads. |
| // TODO(asanka): Remove this container in favor of downloads_by_guid_ as a |
| // part of http://crbug.com/593020. |
| std::unordered_map<uint32_t, std::unique_ptr<DownloadItemImpl>> downloads_; |
| |
| // Same as the above, but maps from GUID to download item. Note that the |
| // container is case sensitive. Hence the key needs to be normalized to |
| // upper-case when inserting new elements here. Fortunately for us, |
| // DownloadItemImpl already normalizes the string GUID. |
| DownloadGuidMap downloads_by_guid_; |
| |
| // True if the download manager has been initialized and requires a shutdown. |
| bool shutdown_needed_; |
| |
| // True if the download manager has been initialized and loaded all the data. |
| bool initialized_; |
| |
| // Whether the history db and/or in progress cache are initialized. |
| bool history_db_initialized_; |
| bool in_progress_cache_initialized_; |
| |
| // Observers that want to be notified of changes to the set of downloads. |
| base::ObserverList<Observer> observers_; |
| |
| // Stores information about in-progress download items. |
| std::unique_ptr<DownloadItem::Observer> in_progress_download_observer_; |
| |
| // The current active browser context. |
| BrowserContext* browser_context_; |
| |
| // Allows an embedder to control behavior. Guaranteed to outlive this object. |
| DownloadManagerDelegate* delegate_; |
| |
| std::vector<UniqueUrlDownloadHandlerPtr> url_download_handlers_; |
| |
| base::WeakPtrFactory<DownloadManagerImpl> weak_factory_; |
| |
| DISALLOW_COPY_AND_ASSIGN(DownloadManagerImpl); |
| }; |
| |
| } // namespace content |
| |
| #endif // CONTENT_BROWSER_DOWNLOAD_DOWNLOAD_MANAGER_IMPL_H_ |