Home | History | Annotate | Download | only in loader
      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_LOADER_RESOURCE_MESSAGE_FILTER_H_
      6 #define CONTENT_BROWSER_LOADER_RESOURCE_MESSAGE_FILTER_H_
      7 
      8 #include "base/callback_forward.h"
      9 #include "base/memory/scoped_ptr.h"
     10 #include "base/memory/weak_ptr.h"
     11 #include "content/common/content_export.h"
     12 #include "content/public/browser/browser_message_filter.h"
     13 #include "webkit/common/resource_type.h"
     14 
     15 struct ResourceHostMsg_Request;
     16 
     17 namespace fileapi {
     18 class FileSystemContext;
     19 }  // namespace fileapi
     20 
     21 namespace net {
     22 class URLRequestContext;
     23 }  // namespace net
     24 
     25 
     26 namespace content {
     27 class ChromeAppCacheService;
     28 class ChromeBlobStorageContext;
     29 class ResourceContext;
     30 
     31 // This class filters out incoming IPC messages for network requests and
     32 // processes them on the IPC thread.  As a result, network requests are not
     33 // delayed by costly UI processing that may be occuring on the main thread of
     34 // the browser.  It also means that any hangs in starting a network request
     35 // will not interfere with browser UI.
     36 class CONTENT_EXPORT ResourceMessageFilter : public BrowserMessageFilter {
     37  public:
     38   typedef base::Callback<void(const ResourceHostMsg_Request&,
     39                               ResourceContext**,
     40                               net::URLRequestContext**)> GetContextsCallback;
     41 
     42   // |appcache_service|, |blob_storage_context|, |file_system_context| may be
     43   // NULL in unittests or for requests from the (NPAPI) plugin process.
     44   ResourceMessageFilter(
     45       int child_id,
     46       int process_type,
     47       ChromeAppCacheService* appcache_service,
     48       ChromeBlobStorageContext* blob_storage_context,
     49       fileapi::FileSystemContext* file_system_context,
     50       const GetContextsCallback& get_contexts_callback);
     51 
     52   // BrowserMessageFilter implementation.
     53   virtual void OnChannelClosing() OVERRIDE;
     54   virtual bool OnMessageReceived(const IPC::Message& message,
     55                                  bool* message_was_ok) OVERRIDE;
     56 
     57   void GetContexts(const ResourceHostMsg_Request& request,
     58                    ResourceContext** resource_context,
     59                    net::URLRequestContext** request_context);
     60 
     61   // Returns the net::URLRequestContext for the given request.
     62   net::URLRequestContext* GetURLRequestContext(
     63       ResourceType::Type request_type);
     64 
     65   ChromeAppCacheService* appcache_service() const {
     66     return appcache_service_.get();
     67   }
     68 
     69   ChromeBlobStorageContext* blob_storage_context() const {
     70     return blob_storage_context_.get();
     71   }
     72 
     73   fileapi::FileSystemContext* file_system_context() const {
     74     return file_system_context_.get();
     75   }
     76 
     77   int child_id() const { return child_id_; }
     78   int process_type() const { return process_type_; }
     79 
     80   base::WeakPtr<ResourceMessageFilter> GetWeakPtr();
     81 
     82  protected:
     83   // Protected destructor so that we can be overriden in tests.
     84   virtual ~ResourceMessageFilter();
     85 
     86  private:
     87   // The ID of the child process.
     88   int child_id_;
     89 
     90   int process_type_;
     91 
     92   scoped_refptr<ChromeAppCacheService> appcache_service_;
     93   scoped_refptr<ChromeBlobStorageContext> blob_storage_context_;
     94   scoped_refptr<fileapi::FileSystemContext> file_system_context_;
     95 
     96   GetContextsCallback get_contexts_callback_;
     97 
     98   // This must come last to make sure weak pointers are invalidated first.
     99   base::WeakPtrFactory<ResourceMessageFilter> weak_ptr_factory_;
    100 
    101   DISALLOW_IMPLICIT_CONSTRUCTORS(ResourceMessageFilter);
    102 };
    103 
    104 }  // namespace content
    105 
    106 #endif  // CONTENT_BROWSER_LOADER_RESOURCE_MESSAGE_FILTER_H_
    107