
The `api_base_url()` and `policy_container()` getters now get their respective objects from the global scope.
79 lines
3.3 KiB
C++
79 lines
3.3 KiB
C++
/*
|
|
* Copyright (c) 2023, Andrew Kaster <akaster@serenityos.org>
|
|
* Copyright (c) 2024, Tim Ledbetter <timledbetter@gmail.com>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibWeb/HTML/Scripting/WorkerEnvironmentSettingsObject.h>
|
|
#include <LibWeb/HTML/WorkerGlobalScope.h>
|
|
|
|
namespace Web::HTML {
|
|
|
|
JS_DEFINE_ALLOCATOR(WorkerEnvironmentSettingsObject);
|
|
|
|
// https://html.spec.whatwg.org/multipage/workers.html#set-up-a-worker-environment-settings-object
|
|
JS::NonnullGCPtr<WorkerEnvironmentSettingsObject> WorkerEnvironmentSettingsObject::setup(JS::NonnullGCPtr<Page> page, NonnullOwnPtr<JS::ExecutionContext> execution_context /* FIXME: null or an environment reservedEnvironment, a URL topLevelCreationURL, and an origin topLevelOrigin */)
|
|
{
|
|
// 1. FIXME: Let inherited origin be outside settings's origin.
|
|
|
|
// 2. Let realm be the value of execution context's Realm component.
|
|
auto realm = execution_context->realm;
|
|
VERIFY(realm);
|
|
|
|
// 3. Let worker global scope be realm's global object.
|
|
auto& worker = verify_cast<HTML::WorkerGlobalScope>(realm->global_object());
|
|
|
|
// 4. Let settings object be a new environment settings object whose algorithms are defined as follows:
|
|
// NOTE: See the functions defined for this class.
|
|
auto settings_object = realm->heap().allocate<WorkerEnvironmentSettingsObject>(*realm, move(execution_context), worker);
|
|
settings_object->target_browsing_context = nullptr;
|
|
|
|
// FIXME: 5. Set settings object's id to a new unique opaque string, creation URL to worker global scope's url, top-level creation URL to null, target browsing context to null, and active service worker to null.
|
|
// FIXME: 6. If worker global scope is a DedicatedWorkerGlobalScope object, then set settings object's top-level origin to outside settings's top-level origin.
|
|
// FIXME: 7. Otherwise, set settings object's top-level origin to an implementation-defined value.
|
|
|
|
// 8. Set realm's [[HostDefined]] field to settings object.
|
|
auto intrinsics = realm->heap().allocate<Bindings::Intrinsics>(*realm, *realm);
|
|
auto host_defined = make<Bindings::HostDefined>(settings_object, intrinsics, page);
|
|
realm->set_host_defined(move(host_defined));
|
|
|
|
// Non-Standard: We cannot fully initialize worker object until *after* the we set up
|
|
// the realm's [[HostDefined]] internal slot as the internal slot contains the web platform intrinsics
|
|
worker.initialize_web_interfaces({});
|
|
|
|
// 9. Return settings object.
|
|
return settings_object;
|
|
}
|
|
|
|
URL::URL WorkerEnvironmentSettingsObject::api_base_url()
|
|
{
|
|
// Return worker global scope's url.
|
|
return m_global_scope->url();
|
|
}
|
|
|
|
Origin WorkerEnvironmentSettingsObject::origin()
|
|
{
|
|
// FIXME: Return a unique opaque origin if worker global scope's url's scheme is "data", and inherited origin otherwise.
|
|
return m_origin;
|
|
}
|
|
|
|
PolicyContainer WorkerEnvironmentSettingsObject::policy_container()
|
|
{
|
|
// Return worker global scope's policy container.
|
|
return m_global_scope->policy_container();
|
|
}
|
|
|
|
CanUseCrossOriginIsolatedAPIs WorkerEnvironmentSettingsObject::cross_origin_isolated_capability()
|
|
{
|
|
// FIXME: Return worker global scope's cross-origin isolated capability.
|
|
return CanUseCrossOriginIsolatedAPIs::No;
|
|
}
|
|
|
|
void WorkerEnvironmentSettingsObject::visit_edges(JS::Cell::Visitor& visitor)
|
|
{
|
|
Base::visit_edges(visitor);
|
|
visitor.visit(m_global_scope);
|
|
}
|
|
|
|
}
|