// 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. #include "net/url_request/url_fetcher_impl.h" #include "base/bind.h" #include "base/message_loop/message_loop_proxy.h" #include "base/sequenced_task_runner.h" #include "net/url_request/url_fetcher_core.h" #include "net/url_request/url_fetcher_factory.h" #include "net/url_request/url_fetcher_response_writer.h" namespace net { static URLFetcherFactory* g_factory = NULL; URLFetcherImpl::URLFetcherImpl(const GURL& url, RequestType request_type, URLFetcherDelegate* d) : core_(new URLFetcherCore(this, url, request_type, d)) { } URLFetcherImpl::~URLFetcherImpl() { core_->Stop(); } void URLFetcherImpl::SetUploadData(const std::string& upload_content_type, const std::string& upload_content) { core_->SetUploadData(upload_content_type, upload_content); } void URLFetcherImpl::SetUploadFilePath( const std::string& upload_content_type, const base::FilePath& file_path, uint64 range_offset, uint64 range_length, scoped_refptr file_task_runner) { core_->SetUploadFilePath(upload_content_type, file_path, range_offset, range_length, file_task_runner); } void URLFetcherImpl::SetChunkedUpload(const std::string& content_type) { core_->SetChunkedUpload(content_type); } void URLFetcherImpl::AppendChunkToUpload(const std::string& data, bool is_last_chunk) { DCHECK(data.length()); core_->AppendChunkToUpload(data, is_last_chunk); } void URLFetcherImpl::SetReferrer(const std::string& referrer) { core_->SetReferrer(referrer); } void URLFetcherImpl::SetReferrerPolicy( URLRequest::ReferrerPolicy referrer_policy) { core_->SetReferrerPolicy(referrer_policy); } void URLFetcherImpl::SetLoadFlags(int load_flags) { core_->SetLoadFlags(load_flags); } int URLFetcherImpl::GetLoadFlags() const { return core_->GetLoadFlags(); } void URLFetcherImpl::SetExtraRequestHeaders( const std::string& extra_request_headers) { core_->SetExtraRequestHeaders(extra_request_headers); } void URLFetcherImpl::AddExtraRequestHeader(const std::string& header_line) { core_->AddExtraRequestHeader(header_line); } void URLFetcherImpl::SetRequestContext( URLRequestContextGetter* request_context_getter) { core_->SetRequestContext(request_context_getter); } void URLFetcherImpl::SetFirstPartyForCookies( const GURL& first_party_for_cookies) { core_->SetFirstPartyForCookies(first_party_for_cookies); } void URLFetcherImpl::SetURLRequestUserData( const void* key, const CreateDataCallback& create_data_callback) { core_->SetURLRequestUserData(key, create_data_callback); } void URLFetcherImpl::SetStopOnRedirect(bool stop_on_redirect) { core_->SetStopOnRedirect(stop_on_redirect); } void URLFetcherImpl::SetAutomaticallyRetryOn5xx(bool retry) { core_->SetAutomaticallyRetryOn5xx(retry); } void URLFetcherImpl::SetMaxRetriesOn5xx(int max_retries) { core_->SetMaxRetriesOn5xx(max_retries); } int URLFetcherImpl::GetMaxRetriesOn5xx() const { return core_->GetMaxRetriesOn5xx(); } base::TimeDelta URLFetcherImpl::GetBackoffDelay() const { return core_->GetBackoffDelay(); } void URLFetcherImpl::SetAutomaticallyRetryOnNetworkChanges(int max_retries) { core_->SetAutomaticallyRetryOnNetworkChanges(max_retries); } void URLFetcherImpl::SaveResponseToFileAtPath( const base::FilePath& file_path, scoped_refptr file_task_runner) { core_->SaveResponseToFileAtPath(file_path, file_task_runner); } void URLFetcherImpl::SaveResponseToTemporaryFile( scoped_refptr file_task_runner) { core_->SaveResponseToTemporaryFile(file_task_runner); } void URLFetcherImpl::SaveResponseWithWriter( scoped_ptr response_writer) { core_->SaveResponseWithWriter(response_writer.Pass()); } HttpResponseHeaders* URLFetcherImpl::GetResponseHeaders() const { return core_->GetResponseHeaders(); } HostPortPair URLFetcherImpl::GetSocketAddress() const { return core_->GetSocketAddress(); } bool URLFetcherImpl::WasFetchedViaProxy() const { return core_->WasFetchedViaProxy(); } void URLFetcherImpl::Start() { core_->Start(); } const GURL& URLFetcherImpl::GetOriginalURL() const { return core_->GetOriginalURL(); } const GURL& URLFetcherImpl::GetURL() const { return core_->GetURL(); } const URLRequestStatus& URLFetcherImpl::GetStatus() const { return core_->GetStatus(); } int URLFetcherImpl::GetResponseCode() const { return core_->GetResponseCode(); } const ResponseCookies& URLFetcherImpl::GetCookies() const { return core_->GetCookies(); } void URLFetcherImpl::ReceivedContentWasMalformed() { core_->ReceivedContentWasMalformed(); } bool URLFetcherImpl::GetResponseAsString( std::string* out_response_string) const { return core_->GetResponseAsString(out_response_string); } bool URLFetcherImpl::GetResponseAsFilePath( bool take_ownership, base::FilePath* out_response_path) const { return core_->GetResponseAsFilePath(take_ownership, out_response_path); } // static void URLFetcherImpl::CancelAll() { URLFetcherCore::CancelAll(); } // static void URLFetcherImpl::SetEnableInterceptionForTests(bool enabled) { URLFetcherCore::SetEnableInterceptionForTests(enabled); } // static void URLFetcherImpl::SetIgnoreCertificateRequests(bool ignored) { URLFetcherCore::SetIgnoreCertificateRequests(ignored); } // static int URLFetcherImpl::GetNumFetcherCores() { return URLFetcherCore::GetNumFetcherCores(); } URLFetcherDelegate* URLFetcherImpl::delegate() const { return core_->delegate(); } // static URLFetcherFactory* URLFetcherImpl::factory() { return g_factory; } // static void URLFetcherImpl::set_factory(URLFetcherFactory* factory) { g_factory = factory; } } // namespace net