blob: cb29a54a1573daa963368f19127e4cd5e15dfa62 [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 "content/browser/web_package/signed_exchange_devtools_proxy.h"
#include "base/bind.h"
#include "base/task/post_task.h"
#include "base/trace_event/trace_event.h"
#include "content/browser/devtools/devtools_instrumentation.h"
#include "content/browser/frame_host/frame_tree_node.h"
#include "content/browser/loader/navigation_url_loader_impl.h"
#include "content/browser/web_package/signed_exchange_envelope.h"
#include "content/browser/web_package/signed_exchange_error.h"
#include "content/public/browser/browser_task_traits.h"
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/render_frame_host.h"
#include "content/public/browser/web_contents.h"
namespace content {
SignedExchangeDevToolsProxy::SignedExchangeDevToolsProxy(
const GURL& outer_request_url,
const network::ResourceResponseHead& outer_response,
base::RepeatingCallback<int(void)> frame_tree_node_id_getter,
base::Optional<const base::UnguessableToken> devtools_navigation_token,
bool report_raw_headers)
: outer_request_url_(outer_request_url),
outer_response_(outer_response),
frame_tree_node_id_getter_(frame_tree_node_id_getter),
devtools_navigation_token_(devtools_navigation_token),
devtools_enabled_(report_raw_headers) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
}
SignedExchangeDevToolsProxy::~SignedExchangeDevToolsProxy() {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
}
void SignedExchangeDevToolsProxy::ReportError(
const std::string& message,
base::Optional<SignedExchangeError::FieldIndexPair> error_field) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
errors_.push_back(SignedExchangeError(message, std::move(error_field)));
WebContents* web_contents =
WebContents::FromFrameTreeNodeId(frame_tree_node_id_getter_.Run());
if (!web_contents)
return;
web_contents->GetMainFrame()->AddMessageToConsole(
blink::mojom::ConsoleMessageLevel::kError, message);
}
void SignedExchangeDevToolsProxy::CertificateRequestSent(
const base::UnguessableToken& request_id,
const network::ResourceRequest& request) {
if (!devtools_enabled_)
return;
FrameTreeNode* frame_tree_node =
FrameTreeNode::GloballyFindByID(frame_tree_node_id_getter_.Run());
if (!frame_tree_node)
return;
devtools_instrumentation::OnSignedExchangeCertificateRequestSent(
frame_tree_node, request_id,
devtools_navigation_token_ ? *devtools_navigation_token_ : request_id,
request, outer_request_url_);
}
void SignedExchangeDevToolsProxy::CertificateResponseReceived(
const base::UnguessableToken& request_id,
const GURL& url,
const network::ResourceResponseHead& head) {
if (!devtools_enabled_)
return;
FrameTreeNode* frame_tree_node =
FrameTreeNode::GloballyFindByID(frame_tree_node_id_getter_.Run());
if (!frame_tree_node)
return;
devtools_instrumentation::OnSignedExchangeCertificateResponseReceived(
frame_tree_node, request_id,
devtools_navigation_token_ ? *devtools_navigation_token_ : request_id,
url, head);
}
void SignedExchangeDevToolsProxy::CertificateRequestCompleted(
const base::UnguessableToken& request_id,
const network::URLLoaderCompletionStatus& status) {
if (!devtools_enabled_)
return;
FrameTreeNode* frame_tree_node =
FrameTreeNode::GloballyFindByID(frame_tree_node_id_getter_.Run());
if (!frame_tree_node)
return;
devtools_instrumentation::OnSignedExchangeCertificateRequestCompleted(
frame_tree_node, request_id, status);
}
void SignedExchangeDevToolsProxy::OnSignedExchangeReceived(
const base::Optional<SignedExchangeEnvelope>& envelope,
const scoped_refptr<net::X509Certificate>& certificate,
const net::SSLInfo* ssl_info) {
DCHECK_CURRENTLY_ON(BrowserThread::UI);
if (!devtools_enabled_)
return;
base::Optional<net::SSLInfo> ssl_info_opt;
if (ssl_info)
ssl_info_opt = *ssl_info;
FrameTreeNode* frame_tree_node =
FrameTreeNode::GloballyFindByID(frame_tree_node_id_getter_.Run());
if (!frame_tree_node)
return;
devtools_instrumentation::OnSignedExchangeReceived(
frame_tree_node, devtools_navigation_token_, outer_request_url_,
outer_response_, envelope, certificate, ssl_info_opt, std::move(errors_));
}
} // namespace content