mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2026-04-19 02:10:26 +00:00
By creating a new FetchController here, we prevent the original FetchController from affecting the actual ongoing request. This is necessary to allow FetchController::stop_fetch() to stop an ongoing fetch in the subsequent commit. The purpose of the copy appears to be only to change the httpFetchParams' request over to the newly-cloned httpRequest, so all existing references should refer back to the originals rather than new instances.
75 lines
2.6 KiB
C++
75 lines
2.6 KiB
C++
/*
|
||
* Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
|
||
*
|
||
* SPDX-License-Identifier: BSD-2-Clause
|
||
*/
|
||
|
||
#include <LibGC/Heap.h>
|
||
#include <LibJS/Runtime/VM.h>
|
||
#include <LibWeb/Fetch/Infrastructure/FetchParams.h>
|
||
#include <LibWeb/Fetch/Infrastructure/HTTP/Responses.h>
|
||
|
||
namespace Web::Fetch::Infrastructure {
|
||
|
||
GC_DEFINE_ALLOCATOR(FetchParams);
|
||
|
||
FetchParams::FetchParams(GC::Ref<Request> request, GC::Ref<FetchAlgorithms> algorithms, GC::Ref<FetchController> controller, GC::Ref<FetchTimingInfo> timing_info)
|
||
: m_request(request)
|
||
, m_algorithms(algorithms)
|
||
, m_controller(controller)
|
||
, m_timing_info(timing_info)
|
||
{
|
||
m_controller->set_fetch_params({}, *this);
|
||
}
|
||
|
||
FetchParams::FetchParams(FetchParams const& params)
|
||
: m_request(params.m_request)
|
||
, m_algorithms(params.m_algorithms)
|
||
, m_task_destination(params.m_task_destination)
|
||
, m_cross_origin_isolated_capability(params.m_cross_origin_isolated_capability)
|
||
, m_controller(params.m_controller)
|
||
, m_timing_info(params.m_timing_info)
|
||
, m_preloaded_response_candidate(params.m_preloaded_response_candidate)
|
||
{
|
||
}
|
||
|
||
GC::Ref<FetchParams> FetchParams::create(JS::VM& vm, GC::Ref<Request> request, GC::Ref<FetchTimingInfo> timing_info)
|
||
{
|
||
auto algorithms = Infrastructure::FetchAlgorithms::create(vm, {});
|
||
auto controller = Infrastructure::FetchController::create(vm);
|
||
return vm.heap().allocate<FetchParams>(request, algorithms, controller, timing_info);
|
||
}
|
||
|
||
GC::Ref<FetchParams> FetchParams::copy(FetchParams const& params)
|
||
{
|
||
return params.vm().heap().allocate<FetchParams>(params);
|
||
}
|
||
|
||
void FetchParams::visit_edges(JS::Cell::Visitor& visitor)
|
||
{
|
||
Base::visit_edges(visitor);
|
||
visitor.visit(m_request);
|
||
visitor.visit(m_algorithms);
|
||
visitor.visit(m_controller);
|
||
visitor.visit(m_timing_info);
|
||
if (m_task_destination.has<GC::Ref<JS::Object>>())
|
||
visitor.visit(m_task_destination.get<GC::Ref<JS::Object>>());
|
||
if (m_preloaded_response_candidate.has<GC::Ref<Response>>())
|
||
visitor.visit(m_preloaded_response_candidate.get<GC::Ref<Response>>());
|
||
}
|
||
|
||
// https://fetch.spec.whatwg.org/#fetch-params-aborted
|
||
bool FetchParams::is_aborted() const
|
||
{
|
||
// A fetch params fetchParams is aborted if its controller’s state is "aborted".
|
||
return m_controller->state() == FetchController::State::Aborted;
|
||
}
|
||
|
||
// https://fetch.spec.whatwg.org/#fetch-params-canceled
|
||
bool FetchParams::is_canceled() const
|
||
{
|
||
// A fetch params fetchParams is canceled if its controller’s state is "aborted" or "terminated".
|
||
return m_controller->state() == FetchController::State::Aborted || m_controller->state() == FetchController::State::Terminated;
|
||
}
|
||
|
||
}
|