// 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 CHROME_BROWSER_DOWNLOAD_DOWNLOAD_RESOURCE_THROTTLE_H_ #define CHROME_BROWSER_DOWNLOAD_DOWNLOAD_RESOURCE_THROTTLE_H_ #include "base/memory/weak_ptr.h" #include "chrome/browser/download/download_request_limiter.h" #include "content/public/browser/resource_throttle.h" class GURL; // DownloadResourceThrottle is used to determine if a download should be // allowed. When a DownloadResourceThrottle is created it pauses the download // and asks the DownloadRequestLimiter if the download should be allowed. The // DownloadRequestLimiter notifies us asynchronously as to whether the download // is allowed or not. If the download is allowed the request is resumed. If // the download is not allowed the request is canceled. class DownloadResourceThrottle : public content::ResourceThrottle, public base::SupportsWeakPtr<DownloadResourceThrottle> { public: DownloadResourceThrottle(DownloadRequestLimiter* limiter, int render_process_id, int render_view_id, int request_id, const std::string& request_method); // content::ResourceThrottle implementation: virtual void WillStartRequest(bool* defer) OVERRIDE; virtual void WillRedirectRequest(const GURL& new_url, bool* defer) OVERRIDE; virtual void WillProcessResponse(bool* defer) OVERRIDE; virtual const char* GetNameForLogging() const OVERRIDE; private: virtual ~DownloadResourceThrottle(); void WillDownload(bool* defer); void ContinueDownload(bool allow); // Set to true when we are querying the DownloadRequestLimiter. bool querying_limiter_; // Set to true when we know that the request is allowed to start. bool request_allowed_; // Set to true when we have deferred the request. bool request_deferred_; DISALLOW_COPY_AND_ASSIGN(DownloadResourceThrottle); }; #endif // CHROME_BROWSER_DOWNLOAD_DOWNLOAD_RESOURCE_THROTTLE_H_