blob: f052eac5c23d4b9a1940bfca06aa20075ae5898c [file] [log] [blame]
// 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/base/network_delegate.h"
#include <utility>
#include "base/logging.h"
#include "base/trace_event/trace_event.h"
#include "net/base/load_flags.h"
#include "net/base/net_errors.h"
#include "net/base/trace_constants.h"
#include "net/proxy_resolution/proxy_info.h"
#include "net/url_request/url_request.h"
namespace net {
NetworkDelegate::~NetworkDelegate() {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
}
int NetworkDelegate::NotifyBeforeURLRequest(URLRequest* request,
CompletionOnceCallback callback,
GURL* new_url) {
TRACE_EVENT0(kNetTracingCategory, "NetworkDelegate::NotifyBeforeURLRequest");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(request);
DCHECK(!callback.is_null());
// ClusterFuzz depends on the following VLOG. See: crbug.com/715656
VLOG(1) << "NetworkDelegate::NotifyBeforeURLRequest: " << request->url();
return OnBeforeURLRequest(request, std::move(callback), new_url);
}
int NetworkDelegate::NotifyBeforeStartTransaction(
URLRequest* request,
CompletionOnceCallback callback,
HttpRequestHeaders* headers) {
TRACE_EVENT0(kNetTracingCategory,
"NetworkDelegate::NotifyBeforeStartTransation");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(headers);
DCHECK(!callback.is_null());
return OnBeforeStartTransaction(request, std::move(callback), headers);
}
void NetworkDelegate::NotifyBeforeSendHeaders(
URLRequest* request,
const ProxyInfo& proxy_info,
const ProxyRetryInfoMap& proxy_retry_info,
HttpRequestHeaders* headers) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(headers);
OnBeforeSendHeaders(request, proxy_info, proxy_retry_info, headers);
}
void NetworkDelegate::NotifyStartTransaction(
URLRequest* request,
const HttpRequestHeaders& headers) {
TRACE_EVENT0(kNetTracingCategory, "NetworkDelegate::NotifyStartTransaction");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
OnStartTransaction(request, headers);
}
int NetworkDelegate::NotifyHeadersReceived(
URLRequest* request,
CompletionOnceCallback callback,
const HttpResponseHeaders* original_response_headers,
scoped_refptr<HttpResponseHeaders>* override_response_headers,
GURL* allowed_unsafe_redirect_url) {
TRACE_EVENT0(kNetTracingCategory, "NetworkDelegate::NotifyHeadersReceived");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(original_response_headers);
DCHECK(!callback.is_null());
return OnHeadersReceived(request, std::move(callback),
original_response_headers, override_response_headers,
allowed_unsafe_redirect_url);
}
void NetworkDelegate::NotifyResponseStarted(URLRequest* request,
int net_error) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(request);
OnResponseStarted(request, net_error);
}
void NetworkDelegate::NotifyNetworkBytesReceived(URLRequest* request,
int64_t bytes_received) {
TRACE_EVENT0(kNetTracingCategory,
"NetworkDelegate::NotifyNetworkBytesReceived");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK_GT(bytes_received, 0);
OnNetworkBytesReceived(request, bytes_received);
}
void NetworkDelegate::NotifyNetworkBytesSent(URLRequest* request,
int64_t bytes_sent) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK_GT(bytes_sent, 0);
OnNetworkBytesSent(request, bytes_sent);
}
void NetworkDelegate::NotifyBeforeRedirect(URLRequest* request,
const GURL& new_location) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(request);
OnBeforeRedirect(request, new_location);
}
void NetworkDelegate::NotifyCompleted(URLRequest* request,
bool started,
int net_error) {
TRACE_EVENT0(kNetTracingCategory, "NetworkDelegate::NotifyCompleted");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(request);
OnCompleted(request, started, net_error);
}
void NetworkDelegate::NotifyURLRequestDestroyed(URLRequest* request) {
TRACE_EVENT0(kNetTracingCategory,
"NetworkDelegate::NotifyURLRequestDestroyed");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(request);
OnURLRequestDestroyed(request);
}
void NetworkDelegate::NotifyPACScriptError(int line_number,
const base::string16& error) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
OnPACScriptError(line_number, error);
}
NetworkDelegate::AuthRequiredResponse NetworkDelegate::NotifyAuthRequired(
URLRequest* request,
const AuthChallengeInfo& auth_info,
AuthCallback callback,
AuthCredentials* credentials) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
return OnAuthRequired(request, auth_info, std::move(callback), credentials);
}
bool NetworkDelegate::CanGetCookies(const URLRequest& request,
const CookieList& cookie_list,
bool allowed_from_caller) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(!(request.load_flags() & LOAD_DO_NOT_SEND_COOKIES));
return OnCanGetCookies(request, cookie_list, allowed_from_caller);
}
bool NetworkDelegate::CanSetCookie(const URLRequest& request,
const CanonicalCookie& cookie,
CookieOptions* options,
bool allowed_from_caller) {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
DCHECK(!(request.load_flags() & LOAD_DO_NOT_SAVE_COOKIES));
return OnCanSetCookie(request, cookie, options, allowed_from_caller);
}
bool NetworkDelegate::CanAccessFile(const URLRequest& request,
const base::FilePath& original_path,
const base::FilePath& absolute_path) const {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
return OnCanAccessFile(request, original_path, absolute_path);
}
bool NetworkDelegate::CanEnablePrivacyMode(const GURL& url,
const GURL& site_for_cookies) const {
TRACE_EVENT0(kNetTracingCategory, "NetworkDelegate::CanEnablePrivacyMode");
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
return OnCanEnablePrivacyMode(url, site_for_cookies);
}
bool NetworkDelegate::AreExperimentalCookieFeaturesEnabled() const {
return OnAreExperimentalCookieFeaturesEnabled();
}
bool NetworkDelegate::CancelURLRequestWithPolicyViolatingReferrerHeader(
const URLRequest& request,
const GURL& target_url,
const GURL& referrer_url) const {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
return OnCancelURLRequestWithPolicyViolatingReferrerHeader(
request, target_url, referrer_url);
}
bool NetworkDelegate::CanQueueReportingReport(const url::Origin& origin) const {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
return OnCanQueueReportingReport(origin);
}
void NetworkDelegate::CanSendReportingReports(
std::set<url::Origin> origins,
base::OnceCallback<void(std::set<url::Origin>)> result_callback) const {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
OnCanSendReportingReports(std::move(origins), std::move(result_callback));
}
bool NetworkDelegate::CanSetReportingClient(const url::Origin& origin,
const GURL& endpoint) const {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
return OnCanSetReportingClient(origin, endpoint);
}
bool NetworkDelegate::CanUseReportingClient(const url::Origin& origin,
const GURL& endpoint) const {
DCHECK_CALLED_ON_VALID_THREAD(thread_checker_);
return OnCanUseReportingClient(origin, endpoint);
}
} // namespace net