|  | // 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. | 
|  |  | 
|  | // This file contains URLFetcher, a wrapper around URLRequest that handles | 
|  | // low-level details like thread safety, ref counting, and incremental buffer | 
|  | // reading.  This is useful for callers who simply want to get the data from a | 
|  | // URL and don't care about all the nitty-gritty details. | 
|  | // | 
|  | // NOTE(willchan): Only one "IO" thread is supported for URLFetcher.  This is a | 
|  | // temporary situation.  We will work on allowing support for multiple "io" | 
|  | // threads per process. | 
|  |  | 
|  | #ifndef NET_URL_REQUEST_URL_FETCHER_IMPL_H_ | 
|  | #define NET_URL_REQUEST_URL_FETCHER_IMPL_H_ | 
|  |  | 
|  | #include <string> | 
|  |  | 
|  | #include "base/basictypes.h" | 
|  | #include "base/compiler_specific.h" | 
|  | #include "net/base/net_export.h" | 
|  | #include "net/url_request/url_fetcher.h" | 
|  |  | 
|  | namespace net { | 
|  | class URLFetcherCore; | 
|  | class URLFetcherDelegate; | 
|  | class URLFetcherFactory; | 
|  |  | 
|  | class NET_EXPORT_PRIVATE URLFetcherImpl : public URLFetcher { | 
|  | public: | 
|  | // |url| is the URL to send the request to. | 
|  | // |request_type| is the type of request to make. | 
|  | // |d| the object that will receive the callback on fetch completion. | 
|  | URLFetcherImpl(const GURL& url, | 
|  | RequestType request_type, | 
|  | URLFetcherDelegate* d); | 
|  | ~URLFetcherImpl() override; | 
|  |  | 
|  | // URLFetcher implementation: | 
|  | void SetUploadData(const std::string& upload_content_type, | 
|  | const std::string& upload_content) override; | 
|  | void SetUploadFilePath( | 
|  | const std::string& upload_content_type, | 
|  | const base::FilePath& file_path, | 
|  | uint64 range_offset, | 
|  | uint64 range_length, | 
|  | scoped_refptr<base::TaskRunner> file_task_runner) override; | 
|  | void SetUploadStreamFactory( | 
|  | const std::string& upload_content_type, | 
|  | const CreateUploadStreamCallback& callback) override; | 
|  | void SetChunkedUpload(const std::string& upload_content_type) override; | 
|  | void AppendChunkToUpload(const std::string& data, | 
|  | bool is_last_chunk) override; | 
|  | void SetLoadFlags(int load_flags) override; | 
|  | int GetLoadFlags() const override; | 
|  | void SetReferrer(const std::string& referrer) override; | 
|  | void SetReferrerPolicy(URLRequest::ReferrerPolicy referrer_policy) override; | 
|  | void SetExtraRequestHeaders( | 
|  | const std::string& extra_request_headers) override; | 
|  | void AddExtraRequestHeader(const std::string& header_line) override; | 
|  | void SetRequestContext( | 
|  | URLRequestContextGetter* request_context_getter) override; | 
|  | void SetFirstPartyForCookies(const GURL& first_party_for_cookies) override; | 
|  | void SetURLRequestUserData( | 
|  | const void* key, | 
|  | const CreateDataCallback& create_data_callback) override; | 
|  | void SetStopOnRedirect(bool stop_on_redirect) override; | 
|  | void SetAutomaticallyRetryOn5xx(bool retry) override; | 
|  | void SetMaxRetriesOn5xx(int max_retries) override; | 
|  | int GetMaxRetriesOn5xx() const override; | 
|  | base::TimeDelta GetBackoffDelay() const override; | 
|  | void SetAutomaticallyRetryOnNetworkChanges(int max_retries) override; | 
|  | void SaveResponseToFileAtPath( | 
|  | const base::FilePath& file_path, | 
|  | scoped_refptr<base::SequencedTaskRunner> file_task_runner) override; | 
|  | void SaveResponseToTemporaryFile( | 
|  | scoped_refptr<base::SequencedTaskRunner> file_task_runner) override; | 
|  | void SaveResponseWithWriter( | 
|  | scoped_ptr<URLFetcherResponseWriter> response_writer) override; | 
|  | HttpResponseHeaders* GetResponseHeaders() const override; | 
|  | HostPortPair GetSocketAddress() const override; | 
|  | bool WasFetchedViaProxy() const override; | 
|  | void Start() override; | 
|  | const GURL& GetOriginalURL() const override; | 
|  | const GURL& GetURL() const override; | 
|  | const URLRequestStatus& GetStatus() const override; | 
|  | int GetResponseCode() const override; | 
|  | const ResponseCookies& GetCookies() const override; | 
|  | void ReceivedContentWasMalformed() override; | 
|  | bool GetResponseAsString(std::string* out_response_string) const override; | 
|  | bool GetResponseAsFilePath(bool take_ownership, | 
|  | base::FilePath* out_response_path) const override; | 
|  |  | 
|  | static void CancelAll(); | 
|  |  | 
|  | static void SetIgnoreCertificateRequests(bool ignored); | 
|  |  | 
|  | // TODO(akalin): Make these private again once URLFetcher::Create() | 
|  | // is in net/. | 
|  |  | 
|  | static URLFetcherFactory* factory(); | 
|  |  | 
|  | // Sets the factory used by the static method Create to create a URLFetcher. | 
|  | // URLFetcher does not take ownership of |factory|. A value of NULL results | 
|  | // in a URLFetcher being created directly. | 
|  | // | 
|  | // NOTE: for safety, this should only be used through ScopedURLFetcherFactory! | 
|  | static void set_factory(URLFetcherFactory* factory); | 
|  |  | 
|  | protected: | 
|  | // Returns the delegate. | 
|  | URLFetcherDelegate* delegate() const; | 
|  |  | 
|  | private: | 
|  | friend class URLFetcherTest; | 
|  |  | 
|  | // Only used by URLFetcherTest, returns the number of URLFetcher::Core objects | 
|  | // actively running. | 
|  | static int GetNumFetcherCores(); | 
|  |  | 
|  | const scoped_refptr<URLFetcherCore> core_; | 
|  |  | 
|  | DISALLOW_COPY_AND_ASSIGN(URLFetcherImpl); | 
|  | }; | 
|  |  | 
|  | }  // namespace net | 
|  |  | 
|  | #endif  // NET_URL_REQUEST_URL_FETCHER_IMPL_H_ |