// Copyright (c) 2010 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 NET_URL_REQUEST_URL_REQUEST_HTTP_JOB_H_ #define NET_URL_REQUEST_URL_REQUEST_HTTP_JOB_H_ #pragma once #include #include #include "base/scoped_ptr.h" #include "base/string16.h" #include "base/task.h" #include "net/base/auth.h" #include "net/base/completion_callback.h" #include "net/http/http_request_info.h" #include "net/url_request/url_request_job.h" #include "net/url_request/url_request_throttler_entry_interface.h" namespace net { class HttpResponseInfo; class HttpTransaction; } class URLRequestContext; // A net::URLRequestJob subclass that is built on top of HttpTransaction. It // provides an implementation for both HTTP and HTTPS. class URLRequestHttpJob : public net::URLRequestJob { public: static net::URLRequestJob* Factory(net::URLRequest* request, const std::string& scheme); protected: explicit URLRequestHttpJob(net::URLRequest* request); // net::URLRequestJob methods: virtual void SetUpload(net::UploadData* upload); virtual void SetExtraRequestHeaders(const net::HttpRequestHeaders& headers); virtual void Start(); virtual void Kill(); virtual net::LoadState GetLoadState() const; virtual uint64 GetUploadProgress() const; virtual bool GetMimeType(std::string* mime_type) const; virtual bool GetCharset(std::string* charset); virtual void GetResponseInfo(net::HttpResponseInfo* info); virtual bool GetResponseCookies(std::vector* cookies); virtual int GetResponseCode() const; virtual bool GetContentEncodings( std::vector* encoding_type); virtual bool IsCachedContent() const { return is_cached_content_; } virtual bool IsSdchResponse() const; virtual bool IsSafeRedirect(const GURL& location); virtual bool NeedsAuth(); virtual void GetAuthChallengeInfo(scoped_refptr*); virtual void SetAuth(const string16& username, const string16& password); virtual void CancelAuth(); virtual void ContinueWithCertificate(net::X509Certificate* client_cert); virtual void ContinueDespiteLastError(); virtual bool ReadRawData(net::IOBuffer* buf, int buf_size, int *bytes_read); virtual void StopCaching(); // Shadows net::URLRequestJob's version of this method so we can grab cookies. void NotifyHeadersComplete(); void DestroyTransaction(); void StartTransaction(); void AddExtraHeaders(); void AddCookieHeaderAndStart(); void SaveCookiesAndNotifyHeadersComplete(); void SaveNextCookie(); void FetchResponseCookies(const net::HttpResponseInfo* response_info, std::vector* cookies); // Process the Strict-Transport-Security header, if one exists. void ProcessStrictTransportSecurityHeader(); void OnCanGetCookiesCompleted(int result); void OnCanSetCookieCompleted(int result); void OnStartCompleted(int result); void OnReadCompleted(int result); bool ShouldTreatAsCertificateError(int result); void RestartTransactionWithAuth(const string16& username, const string16& password); // Keep a reference to the url request context to be sure it's not deleted // before us. scoped_refptr context_; net::HttpRequestInfo request_info_; const net::HttpResponseInfo* response_info_; std::vector response_cookies_; size_t response_cookies_save_index_; // Auth states for proxy and origin server. net::AuthState proxy_auth_state_; net::AuthState server_auth_state_; string16 username_; string16 password_; net::CompletionCallbackImpl can_get_cookies_callback_; net::CompletionCallbackImpl can_set_cookie_callback_; net::CompletionCallbackImpl start_callback_; net::CompletionCallbackImpl read_callback_; bool read_in_progress_; // An URL for an SDCH dictionary as suggested in a Get-Dictionary HTTP header. GURL sdch_dictionary_url_; scoped_ptr transaction_; // This is used to supervise traffic and enforce exponential back-off. scoped_refptr throttling_entry_; // Indicated if an SDCH dictionary was advertised, and hence an SDCH // compressed response is expected. We use this to help detect (accidental?) // proxy corruption of a response, which sometimes marks SDCH content as // having no content encoding . bool sdch_dictionary_advertised_; // For SDCH latency experiments, when we are able to do SDCH, we may enable // either an SDCH latency test xor a pass through test. The following bools // indicate what we decided on for this instance. bool sdch_test_activated_; // Advertising a dictionary for sdch. bool sdch_test_control_; // Not even accepting-content sdch. // For recording of stats, we need to remember if this is cached content. bool is_cached_content_; private: virtual ~URLRequestHttpJob(); ScopedRunnableMethodFactory method_factory_; DISALLOW_COPY_AND_ASSIGN(URLRequestHttpJob); }; #endif // NET_URL_REQUEST_URL_REQUEST_HTTP_JOB_H_