blob: e24fde1cb987a760120e9f3420dc51fb3c1b7218 [file] [log] [blame]
// Copyright 2019 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 "content/browser/loader/browser_initiated_resource_request.h"
#include "base/command_line.h"
#include "base/metrics/field_trial_params.h"
#include "content/common/content_constants_internal.h"
#include "content/public/browser/browser_context.h"
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/content_browser_client.h"
#include "content/public/common/content_client.h"
#include "content/public/common/content_features.h"
#include "content/public/common/content_switches.h"
#include "content/public/common/origin_util.h"
#include "net/http/http_request_headers.h"
#include "services/network/public/cpp/features.h"
#include "services/network/public/cpp/request_mode.h"
#include "services/network/public/cpp/resource_request.h"
#include "third_party/blink/public/common/loader/request_destination.h"
#include "third_party/blink/public/mojom/renderer_preferences.mojom.h"
namespace content {
bool IsFetchMetadataEnabled() {
return base::CommandLine::ForCurrentProcess()->HasSwitch(
switches::kEnableExperimentalWebPlatformFeatures) ||
base::FeatureList::IsEnabled(network::features::kFetchMetadata);
}
bool IsFetchMetadataDestinationEnabled() {
return base::CommandLine::ForCurrentProcess()->HasSwitch(
switches::kEnableExperimentalWebPlatformFeatures) ||
base::FeatureList::IsEnabled(
network::features::kFetchMetadataDestination);
}
void SetFetchMetadataHeadersForBrowserInitiatedRequest(
network::ResourceRequest* resource_request) {
if (IsFetchMetadataEnabled() && IsOriginSecure(resource_request->url)) {
// Sec-Fetch-Mode exposes request's mode.
// https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-mode-header
resource_request->headers.SetHeaderIfMissing(
"Sec-Fetch-Mode", network::RequestModeToString(resource_request->mode));
if (IsFetchMetadataDestinationEnabled()) {
// Sec-Fetch-Dest exposes request's destination.
// https://w3c.github.io/webappsec-fetch-metadata/#sec-fetch-dest-header
auto context_type = static_cast<blink::mojom::RequestContextType>(
resource_request->fetch_request_context_type);
resource_request->headers.SetHeaderIfMissing(
"Sec-Fetch-Dest",
blink::GetRequestDestinationFromContext(context_type));
}
// `Sec-Fetch-User` header is always false (and therefore omitted) because
// this currently does not support navigation requests.
// TODO(shimazu): support navigation requests.
// `Sec-Fetch-Site` is covered elsewhere - by the
// network::SetSecFetchSiteHeader function.
}
}
void UpdateAdditionalHeadersForBrowserInitiatedRequest(
net::HttpRequestHeaders* headers,
BrowserContext* browser_context,
bool should_update_existing_headers,
const blink::mojom::RendererPreferences& renderer_preferences) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
// Set the DoNotTrack header if appropriate.
// https://w3c.github.io/dnt/drafts/tracking-dnt.html#expression-format
if (renderer_preferences.enable_do_not_track) {
if (should_update_existing_headers) {
headers->RemoveHeader(kDoNotTrackHeader);
}
headers->SetHeaderIfMissing(kDoNotTrackHeader, "1");
}
// Set the Save-Data header if appropriate.
// https://tools.ietf.org/html/draft-grigorik-http-client-hints-03#section-7
if (GetContentClient()->browser()->IsDataSaverEnabled(browser_context) &&
!base::GetFieldTrialParamByFeatureAsBool(features::kDataSaverHoldback,
"holdback_web", false)) {
if (should_update_existing_headers) {
headers->RemoveHeader("Save-Data");
}
headers->SetHeaderIfMissing("Save-Data", "on");
}
}
} // namespace content