| // Copyright (c) 2011 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_RENDERER_SECURITY_FILTER_PEER_H_ |
| #define CHROME_RENDERER_SECURITY_FILTER_PEER_H_ |
| |
| #include "content/public/child/request_peer.h" |
| #include "content/public/common/resource_response_info.h" |
| #include "content/public/common/resource_type.h" |
| |
| // The SecurityFilterPeer is a proxy to a |
| // content::RequestPeer instance. It is used to pre-process |
| // unsafe resources (such as mixed-content resource). |
| // Call the factory method CreateSecurityFilterPeer() to obtain an instance of |
| // SecurityFilterPeer based on the original Peer. |
| // NOTE: subclasses should insure they delete themselves at the end of the |
| // OnReceiveComplete call. |
| class SecurityFilterPeer : public content::RequestPeer { |
| public: |
| virtual ~SecurityFilterPeer(); |
| |
| static SecurityFilterPeer* CreateSecurityFilterPeerForDeniedRequest( |
| content::ResourceType::Type resource_type, |
| content::RequestPeer* peer, |
| int os_error); |
| |
| static SecurityFilterPeer* CreateSecurityFilterPeerForFrame( |
| content::RequestPeer* peer, |
| int os_error); |
| |
| // content::RequestPeer methods. |
| virtual void OnUploadProgress(uint64 position, uint64 size) OVERRIDE; |
| virtual bool OnReceivedRedirect( |
| const GURL& new_url, |
| const GURL& new_first_party_for_cookies, |
| const content::ResourceResponseInfo& info) OVERRIDE; |
| virtual void OnReceivedResponse( |
| const content::ResourceResponseInfo& info) OVERRIDE; |
| virtual void OnDownloadedData(int len, int encoded_data_length) OVERRIDE {} |
| virtual void OnReceivedData(const char* data, |
| int data_length, |
| int encoded_data_length) OVERRIDE; |
| virtual void OnCompletedRequest(int error_code, |
| bool was_ignored_by_handler, |
| bool stale_copy_in_cache, |
| const std::string& security_info, |
| const base::TimeTicks& completion_time, |
| int64 total_transfer_size) OVERRIDE; |
| |
| protected: |
| explicit SecurityFilterPeer(content::RequestPeer* peer); |
| |
| content::RequestPeer* original_peer_; |
| |
| private: |
| DISALLOW_COPY_AND_ASSIGN(SecurityFilterPeer); |
| }; |
| |
| // The BufferedPeer reads all the data of the request into an internal buffer. |
| // Subclasses should implement DataReady() to process the data as necessary. |
| class BufferedPeer : public SecurityFilterPeer { |
| public: |
| BufferedPeer(content::RequestPeer* peer, const std::string& mime_type); |
| virtual ~BufferedPeer(); |
| |
| // content::RequestPeer Implementation. |
| virtual void OnReceivedResponse( |
| const content::ResourceResponseInfo& info) OVERRIDE; |
| virtual void OnReceivedData(const char* data, |
| int data_length, |
| int encoded_data_length) OVERRIDE; |
| virtual void OnCompletedRequest( |
| int error_code, |
| bool was_ignored_by_handler, |
| bool stale_copy_in_cache, |
| const std::string& security_info, |
| const base::TimeTicks& completion_time, |
| int64 total_transfer_size) OVERRIDE; |
| |
| protected: |
| // Invoked when the entire request has been processed before the data is sent |
| // to the original peer, giving an opportunity to subclasses to process the |
| // data in data_. If this method returns true, the data is fed to the |
| // original peer, if it returns false, an error is sent instead. |
| virtual bool DataReady() = 0; |
| |
| content::ResourceResponseInfo response_info_; |
| std::string data_; |
| |
| private: |
| std::string mime_type_; |
| |
| DISALLOW_COPY_AND_ASSIGN(BufferedPeer); |
| }; |
| |
| // The ReplaceContentPeer cancels the request and serves the provided data as |
| // content instead. |
| // TODO(jcampan): For now the resource is still being fetched, but ignored, as |
| // once we have provided the replacement content, the associated pending request |
| // in ResourceDispatcher is removed and further OnReceived* notifications are |
| // ignored. |
| class ReplaceContentPeer : public SecurityFilterPeer { |
| public: |
| ReplaceContentPeer(content::RequestPeer* peer, |
| const std::string& mime_type, |
| const std::string& data); |
| virtual ~ReplaceContentPeer(); |
| |
| // content::RequestPeer Implementation. |
| virtual void OnReceivedResponse( |
| const content::ResourceResponseInfo& info) OVERRIDE; |
| virtual void OnReceivedData(const char* data, |
| int data_length, |
| int encoded_data_length) OVERRIDE; |
| virtual void OnCompletedRequest( |
| int error_code, |
| bool was_ignored_by_handler, |
| bool stale_copy_in_cache, |
| const std::string& security_info, |
| const base::TimeTicks& completion_time, |
| int64 total_transfer_size) OVERRIDE; |
| |
| private: |
| content::ResourceResponseInfo response_info_; |
| std::string mime_type_; |
| std::string data_; |
| |
| DISALLOW_COPY_AND_ASSIGN(ReplaceContentPeer); |
| }; |
| |
| #endif // CHROME_RENDERER_SECURITY_FILTER_PEER_H_ |