blob: 7d2d4ba83ae7339bc66a3aec7a3aaefe2ea59927 [file] [log] [blame]
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CONTENT_BROWSER_LOADER_NAVIGATION_URL_LOADER_H_
#define CONTENT_BROWSER_LOADER_NAVIGATION_URL_LOADER_H_
#include <memory>
#include <string>
#include <vector>
#include "content/browser/loader/navigation_loader_interceptor.h"
#include "content/common/content_export.h"
#include "services/network/public/mojom/cookie_access_observer.mojom.h"
#include "services/network/public/mojom/device_bound_sessions.mojom-forward.h"
#include "services/network/public/mojom/devtools_observer.mojom-forward.h"
#include "services/network/public/mojom/shared_dictionary_access_observer.mojom.h"
#include "services/network/public/mojom/trust_token_access_observer.mojom-forward.h"
#include "services/network/public/mojom/url_loader_network_service_observer.mojom.h"
namespace net {
class HttpRequestHeaders;
}
namespace content {
class BrowserContext;
class NavigationUIData;
class NavigationURLLoaderDelegate;
class NavigationURLLoaderFactory;
class PrefetchedSignedExchangeCache;
class ServiceWorkerMainResourceHandle;
class StoragePartition;
struct NavigationRequestInfo;
// The navigation logic's UI thread entry point into the resource loading stack.
// It exposes an interface to control the request prior to receiving the
// response. If the NavigationURLLoader is destroyed before OnResponseStarted is
// called, the request is aborted.
class CONTENT_EXPORT NavigationURLLoader {
public:
enum class LoaderType {
// Creates a regular NavigationURLLoader.
kRegular,
// Creates a noop NavigationURLLoader for BackForwardCache activation.
kNoopForBackForwardCache,
// Creates a noop NavigationURLLoader for Prerender activation.
kNoopForPrerender,
};
// Creates a NavigationURLLoader. The caller is responsible for ensuring that
// `delegate` outlives the loader. `request_body` must not be accessed on the
// UI thread after this point.
//
// If `loader_type` is LoaderType::kNoopForBackForwardCache or
// LoaderType::kNoopoForPrerender, a noop CachedNavigationURLLoader will be
// returned.
//
// TODO(davidben): When navigation is disentangled from the loader, the
// request parameters should not come in as a navigation-specific
// structure. Information like `has_user_gesture` and
// `should_replace_current_entry` in `request_info->common_params` shouldn't
// be needed at this layer.
static std::unique_ptr<NavigationURLLoader> Create(
BrowserContext* browser_context,
StoragePartition* storage_partition,
std::unique_ptr<NavigationRequestInfo> request_info,
std::unique_ptr<NavigationUIData> navigation_ui_data,
ServiceWorkerMainResourceHandle* service_worker_handle,
scoped_refptr<PrefetchedSignedExchangeCache>
prefetched_signed_exchange_cache,
NavigationURLLoaderDelegate* delegate,
LoaderType loader_type,
mojo::PendingRemote<network::mojom::CookieAccessObserver> cookie_observer,
mojo::PendingRemote<network::mojom::TrustTokenAccessObserver>
trust_token_observer,
mojo::PendingRemote<network::mojom::SharedDictionaryAccessObserver>
shared_dictionary_observer,
mojo::PendingRemote<network::mojom::URLLoaderNetworkServiceObserver>
url_loader_network_observer,
mojo::PendingRemote<network::mojom::DevToolsObserver> devtools_observer,
mojo::PendingRemote<network::mojom::DeviceBoundSessionAccessObserver>
device_bound_session_observer,
network::mojom::URLResponseHeadPtr cached_response_head = nullptr,
std::vector<std::unique_ptr<NavigationLoaderInterceptor>>
initial_interceptors = {});
// For testing purposes; sets the factory for use in testing. The factory is
// not used for prerendered page activation as it needs to run a specific
// loader to satisfy its unique requirement. See the implementation comment in
// NavigationURLLoader::Create() for details.
// TODO(crbug.com/40188852): Update this comment for restoration from
// BackForwardCache when it also starts depending on the requirement.
static void SetFactoryForTesting(NavigationURLLoaderFactory* factory);
NavigationURLLoader(const NavigationURLLoader&) = delete;
NavigationURLLoader& operator=(const NavigationURLLoader&) = delete;
virtual ~NavigationURLLoader() {}
// Called right after the loader is constructed.
virtual void Start() = 0;
// Called in response to OnRequestRedirected to continue processing the
// request.
virtual void FollowRedirect(
std::vector<std::string> removed_headers,
net::HttpRequestHeaders modified_headers,
net::HttpRequestHeaders modified_cors_exempt_headers) = 0;
// Sets an overall request timeout for this navigation, which will cause the
// navigation to fail if it expires before the navigation commits. This is
// separate from any //net level timeouts. Returns `true` if the timeout was
// started successfully. Repeated calls will be ignored (they won't reset the
// timeout) and will return `false`.
virtual bool SetNavigationTimeout(base::TimeDelta timeout) = 0;
// Cancels the request timeout for this navigation. If the navigation is still
// happening, it will continue as if the timer wasn't set. Otherwise, this is
// a no-op.
virtual void CancelNavigationTimeout() = 0;
static uint32_t GetURLLoaderOptions(bool is_outermost_main_frame);
protected:
NavigationURLLoader() {}
};
} // namespace content
#endif // CONTENT_BROWSER_LOADER_NAVIGATION_URL_LOADER_H_