WorkerGlobalScope.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /*
  2. * Copyright (c) 2022, Andrew Kaster <akaster@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Optional.h>
  8. #include <AK/RefCounted.h>
  9. #include <AK/URL.h>
  10. #include <LibWeb/Bindings/Wrappable.h>
  11. #include <LibWeb/DOM/EventTarget.h>
  12. #include <LibWeb/DOM/ExceptionOr.h>
  13. #include <LibWeb/Forward.h>
  14. #include <LibWeb/HTML/WorkerLocation.h>
  15. #include <LibWeb/HTML/WorkerNavigator.h>
  16. #define ENUMERATE_WORKER_GLOBAL_SCOPE_EVENT_HANDLERS(E) \
  17. E(onerror, HTML::EventNames::error) \
  18. E(onlanguagechange, HTML::EventNames::languagechange) \
  19. E(ononline, HTML::EventNames::online) \
  20. E(onoffline, HTML::EventNames::offline) \
  21. E(onrejectionhandled, HTML::EventNames::rejectionhandled) \
  22. E(onunhandledrejection, HTML::EventNames::unhandledrejection)
  23. namespace Web::HTML {
  24. // https://html.spec.whatwg.org/multipage/workers.html#the-workerglobalscope-common-interface
  25. // WorkerGlobalScope is the base class of each real WorkerGlobalScope that will be created when the
  26. // user agent runs the run a worker algorithm.
  27. class WorkerGlobalScope
  28. : public RefCounted<WorkerGlobalScope>
  29. , public DOM::EventTarget
  30. , public Bindings::Wrappable {
  31. public:
  32. using WrapperType = Bindings::WorkerGlobalScopeWrapper;
  33. using RefCounted::ref;
  34. using RefCounted::unref;
  35. virtual ~WorkerGlobalScope() override;
  36. // ^EventTarget
  37. virtual void ref_event_target() override { ref(); }
  38. virtual void unref_event_target() override { unref(); }
  39. virtual JS::Object* create_wrapper(JS::GlobalObject&) override;
  40. // Following methods are from the WorkerGlobalScope IDL definition
  41. // https://html.spec.whatwg.org/multipage/workers.html#the-workerglobalscope-common-interface
  42. // https://html.spec.whatwg.org/multipage/workers.html#dom-workerglobalscope-self
  43. NonnullRefPtr<WorkerGlobalScope const> self() const { return *this; }
  44. NonnullRefPtr<WorkerLocation const> location() const;
  45. NonnullRefPtr<WorkerNavigator const> navigator() const;
  46. DOM::ExceptionOr<void> import_scripts(Vector<String> urls);
  47. #undef __ENUMERATE
  48. #define __ENUMERATE(attribute_name, event_name) \
  49. void set_##attribute_name(Optional<Bindings::CallbackType>); \
  50. Bindings::CallbackType* attribute_name();
  51. ENUMERATE_WORKER_GLOBAL_SCOPE_EVENT_HANDLERS(__ENUMERATE)
  52. #undef __ENUMERATE
  53. // Following methods are from the WindowOrWorkerGlobalScope mixin
  54. // https://html.spec.whatwg.org/multipage/webappapis.html#windoworworkerglobalscope-mixin
  55. String origin() const;
  56. bool is_secure_context() const;
  57. bool cross_origin_isolated() const;
  58. DOM::ExceptionOr<String> btoa(String const& data) const;
  59. DOM::ExceptionOr<String> atob(String const& data) const;
  60. // Non-IDL public methods
  61. AK::URL const& url() const { return m_url.value(); }
  62. void set_url(AK::URL const& url) { m_url = url; }
  63. // Spec note: While the WorkerLocation object is created after the WorkerGlobalScope object,
  64. // this is not problematic as it cannot be observed from script.
  65. void set_location(NonnullRefPtr<WorkerLocation> loc) { m_location = move(loc); }
  66. protected:
  67. explicit WorkerGlobalScope();
  68. private:
  69. RefPtr<WorkerLocation> m_location;
  70. // FIXME: Implement WorkerNavigator according to the spec
  71. NonnullRefPtr<WorkerNavigator> m_navigator;
  72. // FIXME: Add all these internal slots
  73. // https://html.spec.whatwg.org/multipage/workers.html#concept-WorkerGlobalScope-owner-set
  74. // A WorkerGlobalScope object has an associated owner set (a set of Document and WorkerGlobalScope objects). It is initially empty and populated when the worker is created or obtained.
  75. // Note: It is a set, instead of a single owner, to accommodate SharedWorkerGlobalScope objects.
  76. // https://html.spec.whatwg.org/multipage/workers.html#concept-workerglobalscope-type
  77. // A WorkerGlobalScope object has an associated type ("classic" or "module"). It is set during creation.
  78. // https://html.spec.whatwg.org/multipage/workers.html#concept-workerglobalscope-url
  79. // A WorkerGlobalScope object has an associated url (null or a URL). It is initially null.
  80. Optional<AK::URL> m_url;
  81. // https://html.spec.whatwg.org/multipage/workers.html#concept-workerglobalscope-name
  82. // A WorkerGlobalScope object has an associated name (a string). It is set during creation.
  83. // Note: The name can have different semantics for each subclass of WorkerGlobalScope.
  84. // For DedicatedWorkerGlobalScope instances, it is simply a developer-supplied name, useful mostly for debugging purposes.
  85. // For SharedWorkerGlobalScope instances, it allows obtaining a reference to a common shared worker via the SharedWorker() constructor.
  86. // For ServiceWorkerGlobalScope objects, it doesn't make sense (and as such isn't exposed through the JavaScript API at all).
  87. // https://html.spec.whatwg.org/multipage/workers.html#concept-workerglobalscope-policy-container
  88. // A WorkerGlobalScope object has an associated policy container (a policy container). It is initially a new policy container.
  89. // https://html.spec.whatwg.org/multipage/workers.html#concept-workerglobalscope-embedder-policy
  90. // A WorkerGlobalScope object has an associated embedder policy (an embedder policy).
  91. // https://html.spec.whatwg.org/multipage/workers.html#concept-workerglobalscope-module-map
  92. // A WorkerGlobalScope object has an associated module map. It is a module map, initially empty.
  93. // https://html.spec.whatwg.org/multipage/workers.html#concept-workerglobalscope-cross-origin-isolated-capability
  94. bool m_cross_origin_isolated_capability { false };
  95. };
  96. }