WorkerEnvironmentSettingsObject.cpp 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. /*
  2. * Copyright (c) 2023, Andrew Kaster <akaster@serenityos.org>
  3. * Copyright (c) 2024, Tim Ledbetter <timledbetter@gmail.com>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #include <LibWeb/HTML/Scripting/WorkerEnvironmentSettingsObject.h>
  8. #include <LibWeb/HTML/WorkerGlobalScope.h>
  9. namespace Web::HTML {
  10. JS_DEFINE_ALLOCATOR(WorkerEnvironmentSettingsObject);
  11. // https://html.spec.whatwg.org/multipage/workers.html#set-up-a-worker-environment-settings-object
  12. 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 */)
  13. {
  14. // 1. FIXME: Let inherited origin be outside settings's origin.
  15. // 2. Let realm be the value of execution context's Realm component.
  16. auto realm = execution_context->realm;
  17. VERIFY(realm);
  18. // 3. Let worker global scope be realm's global object.
  19. auto& worker = verify_cast<HTML::WorkerGlobalScope>(realm->global_object());
  20. // 4. Let settings object be a new environment settings object whose algorithms are defined as follows:
  21. // NOTE: See the functions defined for this class.
  22. auto settings_object = realm->heap().allocate<WorkerEnvironmentSettingsObject>(*realm, move(execution_context), worker);
  23. settings_object->target_browsing_context = nullptr;
  24. // 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.
  25. // 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.
  26. // FIXME: 7. Otherwise, set settings object's top-level origin to an implementation-defined value.
  27. // 8. Set realm's [[HostDefined]] field to settings object.
  28. auto intrinsics = realm->heap().allocate<Bindings::Intrinsics>(*realm, *realm);
  29. auto host_defined = make<Bindings::HostDefined>(settings_object, intrinsics, page);
  30. realm->set_host_defined(move(host_defined));
  31. // Non-Standard: We cannot fully initialize worker object until *after* the we set up
  32. // the realm's [[HostDefined]] internal slot as the internal slot contains the web platform intrinsics
  33. worker.initialize_web_interfaces({});
  34. // 9. Return settings object.
  35. return settings_object;
  36. }
  37. URL::URL WorkerEnvironmentSettingsObject::api_base_url()
  38. {
  39. // Return worker global scope's url.
  40. return m_global_scope->url();
  41. }
  42. Origin WorkerEnvironmentSettingsObject::origin()
  43. {
  44. // FIXME: Return a unique opaque origin if worker global scope's url's scheme is "data", and inherited origin otherwise.
  45. return m_origin;
  46. }
  47. PolicyContainer WorkerEnvironmentSettingsObject::policy_container()
  48. {
  49. // Return worker global scope's policy container.
  50. return m_global_scope->policy_container();
  51. }
  52. CanUseCrossOriginIsolatedAPIs WorkerEnvironmentSettingsObject::cross_origin_isolated_capability()
  53. {
  54. // FIXME: Return worker global scope's cross-origin isolated capability.
  55. return CanUseCrossOriginIsolatedAPIs::No;
  56. }
  57. void WorkerEnvironmentSettingsObject::visit_edges(JS::Cell::Visitor& visitor)
  58. {
  59. Base::visit_edges(visitor);
  60. visitor.visit(m_global_scope);
  61. }
  62. }