blob: 7ca032b850721f8ba1aadddfab1ccc17baf74676 [file] [log] [blame]
// Copyright 2018 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 "services/network/initiator_lock_compatibility.h"
#include "base/feature_list.h"
#include "base/logging.h"
#include "net/base/registry_controlled_domains/registry_controlled_domain.h"
#include "services/network/public/cpp/features.h"
#include "services/network/public/cpp/resource_request.h"
#include "services/network/public/mojom/network_context.mojom.h"
#include "url/gurl.h"
#include "url/origin.h"
#include "url/url_constants.h"
namespace network {
InitiatorLockCompatibility VerifyRequestInitiatorLock(
const base::Optional<url::Origin>& request_initiator_site_lock,
const base::Optional<url::Origin>& request_initiator) {
if (!request_initiator_site_lock.has_value())
return InitiatorLockCompatibility::kNoLock;
const url::Origin& lock = request_initiator_site_lock.value();
if (!request_initiator.has_value()) {
// This should only happen for the browser process (or if NetworkService is
// not enabled).
DCHECK(!base::FeatureList::IsEnabled(network::features::kNetworkService));
return InitiatorLockCompatibility::kNoInitiator;
}
const url::Origin& initiator = request_initiator.value();
// TODO(lukasza, nasko): Also consider equality of precursor origins (e.g. if
// |initiator| is opaque, then it's precursor origin should match the |lock|
// [or |lock|'s precursor if |lock| is also opaque]).
if (initiator.opaque() || (initiator == lock))
return InitiatorLockCompatibility::kCompatibleLock;
// TODO(lukasza, nasko): https://crbug.com/888079: Return kIncorrectLock if
// the origins do not match exactly in the previous if statement. This should
// be possible to do once we no longer fall back to site_url and have
// request_initiator_*origin*_lock instead. The fallback will go away after:
// - We have precursor origins: https://crbug.com/888079
// and
// - We no longer vend process-wide factory: https://crbug.com/891872
if (!initiator.opaque() && !lock.opaque() &&
initiator.scheme() == lock.scheme() &&
initiator.GetURL().SchemeIsHTTPOrHTTPS() &&
!initiator.GetURL().HostIsIPAddress()) {
std::string lock_domain = lock.host();
if (!lock_domain.empty() && lock_domain.back() == '.')
lock_domain.erase(lock_domain.length() - 1);
if (initiator.DomainIs(lock_domain))
return InitiatorLockCompatibility::kCompatibleLock;
}
return InitiatorLockCompatibility::kIncorrectLock;
}
InitiatorLockCompatibility VerifyRequestInitiatorLock(
const mojom::URLLoaderFactoryParams& factory_params,
const ResourceRequest& request) {
if (factory_params.process_id == mojom::kBrowserProcessId)
return InitiatorLockCompatibility::kBrowserProcess;
return VerifyRequestInitiatorLock(factory_params.request_initiator_site_lock,
request.request_initiator);
}
} // namespace network