blob: 577d8eebffb39056567630a6148cf72beee43727 [file] [log] [blame]
// Copyright 2013 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.
#include <string>
#include "content/public/child/request_peer.h"
#include "content/public/common/resource_response_info.h"
namespace IPC {
class Sender;
// The ExtensionLocalizationPeer is a proxy to a
// content::RequestPeer instance. It is used to pre-process
// CSS files requested by extensions to replace localization templates with the
// appropriate localized strings.
// Call the factory method CreateExtensionLocalizationPeer() to obtain an
// instance of ExtensionLocalizationPeer based on the original Peer.
class ExtensionLocalizationPeer : public content::RequestPeer {
~ExtensionLocalizationPeer() override;
static ExtensionLocalizationPeer* CreateExtensionLocalizationPeer(
content::RequestPeer* peer,
IPC::Sender* message_sender,
const std::string& mime_type,
const GURL& request_url);
// content::RequestPeer methods.
void OnUploadProgress(uint64 position, uint64 size) override;
bool OnReceivedRedirect(const net::RedirectInfo& redirect_info,
const content::ResourceResponseInfo& info) override;
void OnReceivedResponse(const content::ResourceResponseInfo& info) override;
void OnDownloadedData(int len, int encoded_data_length) override {}
void OnReceivedData(const char* data,
int data_length,
int encoded_data_length) override;
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;
friend class ExtensionLocalizationPeerTest;
// Use CreateExtensionLocalizationPeer to create an instance.
ExtensionLocalizationPeer(content::RequestPeer* peer,
IPC::Sender* message_sender,
const GURL& request_url);
// Loads message catalogs, and replaces all __MSG_some_name__ templates within
// loaded file.
void ReplaceMessages();
// Original peer that handles the request once we are done processing data_.
content::RequestPeer* original_peer_;
// We just pass though the response info. This holds the copy of the original.
content::ResourceResponseInfo response_info_;
// Sends ExtensionHostMsg_GetMessageBundle message to the browser to fetch
// message catalog.
IPC::Sender* message_sender_;
// Buffer for incoming data. We wait until OnCompletedRequest before using it.
std::string data_;
// Original request URL.
GURL request_url_;