// Copyright (c) 2012 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 CONTENT_PUBLIC_BROWSER_RESOURCE_CONTEXT_H_ #define CONTENT_PUBLIC_BROWSER_RESOURCE_CONTEXT_H_ #include <string> #include "base/basictypes.h" #include "base/callback.h" #include "base/memory/scoped_ptr.h" #include "base/supports_user_data.h" #include "build/build_config.h" #include "content/common/content_export.h" class GURL; namespace appcache { class AppCacheService; } namespace net { class ClientCertStore; class HostResolver; class KeygenHandler; class URLRequestContext; } namespace content { // ResourceContext contains the relevant context information required for // resource loading. It lives on the IO thread, although it is constructed on // the UI thread. It must be destructed on the IO thread. class CONTENT_EXPORT ResourceContext : public base::SupportsUserData { public: #if defined(OS_IOS) virtual ~ResourceContext() {} #else ResourceContext(); virtual ~ResourceContext(); #endif virtual net::HostResolver* GetHostResolver() = 0; // DEPRECATED: This is no longer a valid given isolated apps/sites and // storage partitioning. This getter returns the default context associated // with a BrowsingContext. virtual net::URLRequestContext* GetRequestContext() = 0; // Get platform ClientCertStore. May return NULL. virtual scoped_ptr<net::ClientCertStore> CreateClientCertStore(); // Create a platform KeygenHandler and pass it to |callback|. The |callback| // may be run synchronously. virtual void CreateKeygenHandler( uint32 key_size_in_bits, const std::string& challenge_string, const GURL& url, const base::Callback<void(scoped_ptr<net::KeygenHandler>)>& callback); // Returns true if microphone access is allowed for |origin|. Used to // determine what level of authorization is given to |origin| to access // resource metadata. virtual bool AllowMicAccess(const GURL& origin) = 0; // Returns true if web camera access is allowed for |origin|. Used to // determine what level of authorization is given to |origin| to access // resource metadata. virtual bool AllowCameraAccess(const GURL& origin) = 0; // Returns a callback that can be invoked to get a random salt // string that is used for creating media device IDs. The salt // should be stored in the current user profile and should be reset // if cookies are cleared. The default is an empty string. // // It is safe to hold on to the callback returned and use it without // regard to the lifetime of ResourceContext, although in general // you should not use it long after the profile has been destroyed. // // TODO(joi): We don't think it should be unnecessary to use this // after ResourceContext goes away. There is likely an underying bug // in the lifetime of ProfileIOData vs. ResourceProcessHost, where // sometimes ProfileIOData has gone away before RPH has finished // being torn down (on the IO thread). The current interface that // allows using the salt object after ResourceContext has gone away // was put in place to fix http://crbug.com/341211 but I intend to // try to figure out how the lifetime should be fixed properly. The // original interface was just a method that returns a string. // // TODO(perkj): Make this method pure virtual when crbug/315022 is // fixed. typedef base::Callback<std::string()> SaltCallback; virtual SaltCallback GetMediaDeviceIDSalt(); }; } // namespace content #endif // CONTENT_PUBLIC_BROWSER_RESOURCE_CONTEXT_H_