Home | History | Annotate | Download | only in download
      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 #ifndef CONTENT_BROWSER_DOWNLOAD_SAVE_FILE_RESOURCE_HANDLER_H_
      6 #define CONTENT_BROWSER_DOWNLOAD_SAVE_FILE_RESOURCE_HANDLER_H_
      7 
      8 #include <string>
      9 
     10 #include "base/memory/ref_counted.h"
     11 #include "content/browser/loader/resource_handler.h"
     12 #include "url/gurl.h"
     13 
     14 namespace net {
     15 class URLRequest;
     16 }
     17 
     18 namespace content {
     19 class SaveFileManager;
     20 
     21 // Forwards data to the save thread.
     22 class SaveFileResourceHandler : public ResourceHandler {
     23  public:
     24   SaveFileResourceHandler(net::URLRequest* request,
     25                           int render_process_host_id,
     26                           int render_view_id,
     27                           const GURL& url,
     28                           SaveFileManager* manager);
     29   virtual ~SaveFileResourceHandler();
     30 
     31   // ResourceHandler Implementation:
     32   virtual bool OnUploadProgress(uint64 position, uint64 size) OVERRIDE;
     33 
     34   // Saves the redirected URL to final_url_, we need to use the original
     35   // URL to match original request.
     36   virtual bool OnRequestRedirected(const net::RedirectInfo& redirect_info,
     37                                    ResourceResponse* response,
     38                                    bool* defer) OVERRIDE;
     39 
     40   // Sends the download creation information to the download thread.
     41   virtual bool OnResponseStarted(ResourceResponse* response,
     42                                  bool* defer) OVERRIDE;
     43 
     44   // Pass-through implementation.
     45   virtual bool OnWillStart(const GURL& url, bool* defer) OVERRIDE;
     46 
     47   // Pass-through implementation.
     48   virtual bool OnBeforeNetworkStart(const GURL& url, bool* defer) OVERRIDE;
     49 
     50   // Creates a new buffer, which will be handed to the download thread for file
     51   // writing and deletion.
     52   virtual bool OnWillRead(scoped_refptr<net::IOBuffer>* buf,
     53                           int* buf_size,
     54                           int min_size) OVERRIDE;
     55 
     56   // Passes the buffer to the download file writer.
     57   virtual bool OnReadCompleted(int bytes_read, bool* defer) OVERRIDE;
     58 
     59   virtual void OnResponseCompleted(const net::URLRequestStatus& status,
     60                                    const std::string& security_info,
     61                                    bool* defer) OVERRIDE;
     62 
     63   // N/A to this flavor of SaveFileResourceHandler.
     64   virtual void OnDataDownloaded(int bytes_downloaded) OVERRIDE;
     65 
     66   // If the content-length header is not present (or contains something other
     67   // than numbers), StringToInt64 returns 0, which indicates 'unknown size' and
     68   // is handled correctly by the SaveManager.
     69   void set_content_length(const std::string& content_length);
     70 
     71   void set_content_disposition(const std::string& content_disposition) {
     72     content_disposition_ = content_disposition;
     73   }
     74 
     75  private:
     76   int save_id_;
     77   int render_process_id_;
     78   int render_view_id_;
     79   scoped_refptr<net::IOBuffer> read_buffer_;
     80   std::string content_disposition_;
     81   GURL url_;
     82   GURL final_url_;
     83   int64 content_length_;
     84   SaveFileManager* save_manager_;
     85 
     86   static const int kReadBufSize = 32768;  // bytes
     87 
     88   DISALLOW_COPY_AND_ASSIGN(SaveFileResourceHandler);
     89 };
     90 
     91 }  // namespace content
     92 
     93 #endif  // CONTENT_BROWSER_DOWNLOAD_SAVE_FILE_RESOURCE_HANDLER_H_
     94