blob: ebff229866c022251e3f1cd2270ec0c49f69e60b [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.
#ifndef CHROME_BROWSER_OFFLINE_PAGES_OFFLINE_PAGE_URL_LOADER_H_
#define CHROME_BROWSER_OFFLINE_PAGES_OFFLINE_PAGE_URL_LOADER_H_
#include <cstdint>
#include "base/memory/weak_ptr.h"
#include "chrome/browser/offline_pages/offline_page_request_handler.h"
#include "content/public/browser/url_loader_request_interceptor.h"
#include "mojo/public/cpp/bindings/binding.h"
#include "mojo/public/cpp/system/data_pipe.h"
#include "services/network/public/mojom/url_loader.mojom.h"
namespace content {
class NavigationUIData;
}
namespace mojo {
class SimpleWatcher;
}
namespace net {
class IOBuffer;
}
namespace offline_pages {
// A url loader that serves offline contents with network service enabled.
class OfflinePageURLLoader : public network::mojom::URLLoader,
public OfflinePageRequestHandler::Delegate {
public:
// Creates and returns a loader to serve the offline page. Nullptr is returned
// if offline page cannot or should not be served.
static std::unique_ptr<OfflinePageURLLoader> Create(
content::NavigationUIData* navigation_ui_data,
int frame_tree_node_id,
const network::ResourceRequest& resource_request,
content::URLLoaderRequestInterceptor::LoaderCallback callback);
~OfflinePageURLLoader() override;
void SetTabIdGetterForTesting(
OfflinePageRequestHandler::Delegate::TabIdGetter tab_id_getter);
using ShouldAllowPreviewCallback = base::RepeatingCallback<bool(void)>;
void SetShouldAllowPreviewCallbackForTesting(
ShouldAllowPreviewCallback should_allow_preview_callback);
private:
OfflinePageURLLoader(
content::NavigationUIData* navigation_ui_data,
int frame_tree_node_id,
const network::ResourceRequest& resource_request,
content::URLLoaderRequestInterceptor::LoaderCallback callback);
// network::mojom::URLLoader:
void FollowRedirect(const base::Optional<std::vector<std::string>>&
to_be_removed_request_headers,
const base::Optional<net::HttpRequestHeaders>&
modified_request_headers) override;
void ProceedWithResponse() override;
void SetPriority(net::RequestPriority priority,
int32_t intra_priority_value) override;
void PauseReadingBodyFromNet() override;
void ResumeReadingBodyFromNet() override;
// OfflinePageRequestHandler::Delegate overrides:
void FallbackToDefault() override;
void NotifyStartError(int error) override;
void NotifyHeadersComplete(int64_t file_size) override;
void NotifyReadRawDataComplete(int bytes_read) override;
void SetOfflinePageNavigationUIData(bool is_offline_page) override;
bool ShouldAllowPreview() const override;
int GetPageTransition() const override;
OfflinePageRequestHandler::Delegate::WebContentsGetter GetWebContentsGetter()
const override;
OfflinePageRequestHandler::Delegate::TabIdGetter GetTabIdGetter()
const override;
void ReadRawData();
void OnReceiveResponse(int64_t file_size,
network::mojom::URLLoaderRequest request,
network::mojom::URLLoaderClientPtr client);
void OnReceiveError(int error,
network::mojom::URLLoaderRequest request,
network::mojom::URLLoaderClientPtr client);
void OnHandleReady(MojoResult result, const mojo::HandleSignalsState& state);
void Finish(int error);
void TransferRawData();
void OnConnectionError();
void MaybeDeleteSelf();
// Not owned. The owner of this should outlive this class instance.
content::NavigationUIData* navigation_ui_data_;
int frame_tree_node_id_;
int transition_type_;
content::URLLoaderRequestInterceptor::LoaderCallback loader_callback_;
std::unique_ptr<OfflinePageRequestHandler> request_handler_;
scoped_refptr<net::IOBuffer> buffer_;
mojo::Binding<network::mojom::URLLoader> binding_;
network::mojom::URLLoaderClientPtr client_;
mojo::ScopedDataPipeProducerHandle producer_handle_;
int bytes_of_raw_data_to_transfer_ = 0;
int write_position_ = 0;
std::unique_ptr<mojo::SimpleWatcher> handle_watcher_;
OfflinePageRequestHandler::Delegate::TabIdGetter tab_id_getter_;
ShouldAllowPreviewCallback should_allow_preview_callback_;
base::WeakPtrFactory<OfflinePageURLLoader> weak_ptr_factory_;
DISALLOW_COPY_AND_ASSIGN(OfflinePageURLLoader);
};
} // namespace offline_pages
#endif // CHROME_BROWSER_OFFLINE_PAGES_OFFLINE_PAGE_URL_LOADER_H_