2022-10-13 19:20:27 +02:00
|
|
|
|
/*
|
|
|
|
|
* Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
|
|
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
|
*/
|
|
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
|
#include <LibGC/Heap.h>
|
2022-10-13 19:20:27 +02:00
|
|
|
|
#include <LibJS/Runtime/VM.h>
|
2025-02-26 15:46:41 +00:00
|
|
|
|
#include <LibRequests/RequestTimingInfo.h>
|
2022-10-13 19:20:27 +02:00
|
|
|
|
#include <LibWeb/Fetch/Infrastructure/FetchTimingInfo.h>
|
2025-02-26 15:46:41 +00:00
|
|
|
|
#include <LibWeb/HighResolutionTime/TimeOrigin.h>
|
2022-10-13 19:20:27 +02:00
|
|
|
|
|
|
|
|
|
namespace Web::Fetch::Infrastructure {
|
|
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
|
GC_DEFINE_ALLOCATOR(FetchTimingInfo);
|
2024-04-06 10:16:04 -07:00
|
|
|
|
|
2022-10-13 19:20:27 +02:00
|
|
|
|
FetchTimingInfo::FetchTimingInfo() = default;
|
|
|
|
|
|
2024-11-15 04:01:23 +13:00
|
|
|
|
GC::Ref<FetchTimingInfo> FetchTimingInfo::create(JS::VM& vm)
|
2022-10-13 19:20:27 +02:00
|
|
|
|
{
|
2024-11-14 06:13:46 +13:00
|
|
|
|
return vm.heap().allocate<FetchTimingInfo>();
|
2022-10-13 19:20:27 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void FetchTimingInfo::visit_edges(JS::Cell::Visitor& visitor)
|
|
|
|
|
{
|
|
|
|
|
Base::visit_edges(visitor);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// https://fetch.spec.whatwg.org/#create-an-opaque-timing-info
|
2024-11-15 04:01:23 +13:00
|
|
|
|
GC::Ref<FetchTimingInfo> create_opaque_timing_info(JS::VM& vm, FetchTimingInfo const& timing_info)
|
2022-10-13 19:20:27 +02:00
|
|
|
|
{
|
|
|
|
|
// To create an opaque timing info, given a fetch timing info timingInfo, return a new fetch timing info whose
|
|
|
|
|
// start time and post-redirect start time are timingInfo’s start time.
|
|
|
|
|
auto new_timing_info = FetchTimingInfo::create(vm);
|
|
|
|
|
new_timing_info->set_start_time(timing_info.start_time());
|
|
|
|
|
new_timing_info->set_post_redirect_start_time(timing_info.start_time());
|
|
|
|
|
return new_timing_info;
|
|
|
|
|
}
|
|
|
|
|
|
2025-02-26 15:46:41 +00:00
|
|
|
|
void FetchTimingInfo::update_final_timings(Requests::RequestTimingInfo const& final_timings, HTML::CanUseCrossOriginIsolatedAPIs cross_origin_isolated_capability)
|
|
|
|
|
{
|
|
|
|
|
bool has_cross_origin_isolated_capability = cross_origin_isolated_capability == HTML::CanUseCrossOriginIsolatedAPIs::Yes;
|
|
|
|
|
|
|
|
|
|
auto domain_lookup_start_time_milliseconds = m_start_time + (static_cast<HighResolutionTime::DOMHighResTimeStamp>(final_timings.domain_lookup_start_microseconds) / 1000.0);
|
|
|
|
|
auto coarsened_domain_lookup_start_time = HighResolutionTime::coarsen_time(domain_lookup_start_time_milliseconds, has_cross_origin_isolated_capability);
|
|
|
|
|
|
|
|
|
|
auto domain_lookup_end_time_milliseconds = m_start_time + (static_cast<HighResolutionTime::DOMHighResTimeStamp>(final_timings.domain_lookup_end_microseconds) / 1000.0);
|
|
|
|
|
auto coarsened_domain_lookup_end_time = HighResolutionTime::coarsen_time(domain_lookup_end_time_milliseconds, has_cross_origin_isolated_capability);
|
|
|
|
|
|
|
|
|
|
auto connect_start_time_milliseconds = m_start_time + (static_cast<HighResolutionTime::DOMHighResTimeStamp>(final_timings.connect_start_microseconds) / 1000.0);
|
|
|
|
|
auto coarsened_connection_start_time = HighResolutionTime::coarsen_time(connect_start_time_milliseconds, has_cross_origin_isolated_capability);
|
|
|
|
|
|
|
|
|
|
auto connect_end_time_milliseconds = m_start_time + (static_cast<HighResolutionTime::DOMHighResTimeStamp>(final_timings.connect_end_microseconds) / 1000.0);
|
|
|
|
|
auto coarsened_connection_end_time = HighResolutionTime::coarsen_time(connect_end_time_milliseconds, has_cross_origin_isolated_capability);
|
|
|
|
|
|
|
|
|
|
auto secure_connect_start_time_milliseconds = m_start_time + (static_cast<HighResolutionTime::DOMHighResTimeStamp>(final_timings.secure_connect_start_microseconds) / 1000.0);
|
|
|
|
|
auto coarsened_secure_connection_start_time = HighResolutionTime::coarsen_time(secure_connect_start_time_milliseconds, has_cross_origin_isolated_capability);
|
|
|
|
|
|
|
|
|
|
m_final_connection_timing_info = ConnectionTimingInfo {
|
|
|
|
|
.domain_lookup_start_time = coarsened_domain_lookup_start_time,
|
|
|
|
|
.domain_lookup_end_time = coarsened_domain_lookup_end_time,
|
|
|
|
|
.connection_start_time = coarsened_connection_start_time,
|
|
|
|
|
.connection_end_time = coarsened_connection_end_time,
|
|
|
|
|
.secure_connection_start_time = coarsened_secure_connection_start_time,
|
|
|
|
|
.alpn_negotiated_protocol = alpn_http_version_to_fly_string(final_timings.http_version_alpn_identifier),
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
auto request_start_time_milliseconds = m_start_time + (static_cast<HighResolutionTime::DOMHighResTimeStamp>(final_timings.request_start_microseconds) / 1000.0);
|
|
|
|
|
auto coarsened_request_start_time = HighResolutionTime::coarsen_time(request_start_time_milliseconds, has_cross_origin_isolated_capability);
|
|
|
|
|
m_final_network_request_start_time = coarsened_request_start_time;
|
|
|
|
|
|
|
|
|
|
auto response_start_time_milliseconds = m_start_time + (static_cast<HighResolutionTime::DOMHighResTimeStamp>(final_timings.response_start_microseconds) / 1000.0);
|
|
|
|
|
auto coarsened_response_start_time = HighResolutionTime::coarsen_time(response_start_time_milliseconds, has_cross_origin_isolated_capability);
|
|
|
|
|
m_final_network_response_start_time = coarsened_response_start_time;
|
|
|
|
|
}
|
|
|
|
|
|
2022-10-13 19:20:27 +02:00
|
|
|
|
}
|