// Copyright (c) 2006-2008 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. // This class represents contextual information (cookies, cache, etc.) // that's useful when processing resource requests. // The class is reference-counted so that it can be cleaned up after any // requests that are using it have been completed. #ifndef NET_URL_REQUEST_URL_REQUEST_CONTEXT_H_ #define NET_URL_REQUEST_URL_REQUEST_CONTEXT_H_ #include "base/ref_counted.h" #include "base/string_util.h" #include "net/base/cookie_policy.h" #include "net/base/cookie_store.h" #include "net/base/host_resolver.h" #include "net/base/ssl_config_service.h" #include "net/base/strict_transport_security_state.h" #include "net/ftp/ftp_auth_cache.h" #include "net/proxy/proxy_service.h" #include "net/url_request/url_request_tracker.h" namespace net { class FtpTransactionFactory; class HttpTransactionFactory; } class URLRequest; // Subclass to provide application-specific context for URLRequest instances. class URLRequestContext : public base::RefCountedThreadSafe { public: URLRequestContext() : http_transaction_factory_(NULL), ftp_transaction_factory_(NULL), cookie_store_(NULL), strict_transport_security_state_(NULL) { } net::HostResolver* host_resolver() const { return host_resolver_; } // Get the proxy service for this context. net::ProxyService* proxy_service() const { return proxy_service_; } // Get the ssl config service for this context. net::SSLConfigService* ssl_config_service() const { return ssl_config_service_; } // Gets the http transaction factory for this context. net::HttpTransactionFactory* http_transaction_factory() const { return http_transaction_factory_; } // Gets the ftp transaction factory for this context. net::FtpTransactionFactory* ftp_transaction_factory() { return ftp_transaction_factory_; } // Gets the cookie store for this context. net::CookieStore* cookie_store() { return cookie_store_.get(); } // Gets the cookie policy for this context. net::CookiePolicy* cookie_policy() { return &cookie_policy_; } net::StrictTransportSecurityState* strict_transport_security_state() { return strict_transport_security_state_; } // Gets the FTP authentication cache for this context. net::FtpAuthCache* ftp_auth_cache() { return &ftp_auth_cache_; } // Gets the value of 'Accept-Charset' header field. const std::string& accept_charset() const { return accept_charset_; } // Gets the value of 'Accept-Language' header field. const std::string& accept_language() const { return accept_language_; } // Gets the tracker for URLRequests associated with this context. URLRequestTracker* request_tracker() { return &request_tracker_; } // Gets the UA string to use for the given URL. Pass an invalid URL (such as // GURL()) to get the default UA string. Subclasses should override this // method to provide a UA string. virtual const std::string& GetUserAgent(const GURL& url) const { return EmptyString(); } // In general, referrer_charset is not known when URLRequestContext is // constructed. So, we need a setter. const std::string& referrer_charset() const { return referrer_charset_; } void set_referrer_charset(const std::string& charset) { referrer_charset_ = charset; } // Called for each cookie returning for the given request. A pointer to // the cookie is passed so that it can be modified. Returns true if the // cookie was not dropped (it could still be modified though). virtual bool InterceptCookie(const URLRequest* request, std::string* cookie) { return true; } // Called before adding cookies to sent requests. Allows overriding // requests to block sending of cookies. virtual bool AllowSendingCookies(const URLRequest* request) const { return true; } protected: friend class base::RefCountedThreadSafe; virtual ~URLRequestContext() {} // The following members are expected to be initialized and owned by // subclasses. scoped_refptr host_resolver_; scoped_refptr proxy_service_; scoped_refptr ssl_config_service_; net::HttpTransactionFactory* http_transaction_factory_; net::FtpTransactionFactory* ftp_transaction_factory_; scoped_refptr cookie_store_; net::CookiePolicy cookie_policy_; scoped_refptr strict_transport_security_state_; net::FtpAuthCache ftp_auth_cache_; std::string accept_language_; std::string accept_charset_; // The charset of the referrer where this request comes from. It's not // used in communication with a server but is used to construct a suggested // filename for file download. std::string referrer_charset_; // Tracks the requests associated with this context. URLRequestTracker request_tracker_; private: DISALLOW_COPY_AND_ASSIGN(URLRequestContext); }; #endif // NET_URL_REQUEST_URL_REQUEST_CONTEXT_H_