// 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 #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 GetCacheThread(); static scoped_refptr 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__