blob: 003cf5afd56c4ea3bd9df0bcdf304c9cfaaa0a68 [file] [log] [blame]
// 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 WEBKIT_TOOLS_TEST_SHELL_SIMPLE_RESOURCE_LOADER_BRIDGE_H__
#define WEBKIT_TOOLS_TEST_SHELL_SIMPLE_RESOURCE_LOADER_BRIDGE_H__
#include <string>
#include "base/message_loop_proxy.h"
#include "net/http/http_cache.h"
#include "webkit/glue/resource_loader_bridge.h"
class FilePath;
class GURL;
class SimpleResourceLoaderBridge {
public:
// Call this function to initialize the simple resource loader bridge.
// It is safe to call this function multiple times.
//
// NOTE: If this function is not called, then a default request context will
// be initialized lazily.
//
static void Init(const FilePath& cache_path,
net::HttpCache::Mode cache_mode,
bool no_proxy);
// Call this function to shutdown the simple resource loader bridge.
static void Shutdown();
// May only be called after Init.
static void SetCookie(const GURL& url,
const GURL& first_party_for_cookies,
const std::string& cookie);
static std::string GetCookies(const GURL& url,
const GURL& first_party_for_cookies);
static bool EnsureIOThread();
static void SetAcceptAllCookies(bool accept_all_cookies);
// These methods should only be called after Init(), and before
// Shutdown(). The MessageLoops get replaced upon each call to
// Init(), and destroyed upon a call to ShutDown().
static scoped_refptr<base::MessageLoopProxy> GetCacheThread();
static scoped_refptr<base::MessageLoopProxy> GetIoThread();
// Call this function to set up whether using file-over-http feature.
// |file_over_http| indicates whether using file-over-http or not.
// If yes, when the request url uses file scheme and matches sub string
// |file_path_template|, SimpleResourceLoaderBridge will use |http_prefix|
// plus string of after |file_path_template| in original request URl to
// generate a new http URL to get the data and send back to peer.
// That is how we implement file-over-http feature.
static void AllowFileOverHTTP(const std::string& file_path_template,
const GURL& http_prefix);
// Creates a ResourceLoaderBridge instance.
static webkit_glue::ResourceLoaderBridge* Create(
const webkit_glue::ResourceLoaderBridge::RequestInfo& request_info);
};
#endif // WEBKIT_TOOLS_TEST_SHELL_SIMPLE_RESOURCE_LOADER_BRIDGE_H__