Request.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. /*
  2. * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Forward.h>
  8. #include <LibJS/Forward.h>
  9. #include <LibWeb/Bindings/PlatformObject.h>
  10. #include <LibWeb/Fetch/Body.h>
  11. #include <LibWeb/Fetch/BodyInit.h>
  12. #include <LibWeb/Fetch/Headers.h>
  13. #include <LibWeb/Fetch/Infrastructure/HTTP/Requests.h>
  14. #include <LibWeb/Forward.h>
  15. namespace Web::Fetch {
  16. // https://fetch.spec.whatwg.org/#requestinfo
  17. using RequestInfo = Variant<JS::Handle<Request>, String>;
  18. // https://fetch.spec.whatwg.org/#requestinit
  19. struct RequestInit {
  20. Optional<String> method;
  21. Optional<HeadersInit> headers;
  22. Optional<Optional<BodyInit>> body;
  23. Optional<String> referrer;
  24. Optional<Bindings::ReferrerPolicy> referrer_policy;
  25. Optional<Bindings::RequestMode> mode;
  26. Optional<Bindings::RequestCredentials> credentials;
  27. Optional<Bindings::RequestCache> cache;
  28. Optional<Bindings::RequestRedirect> redirect;
  29. Optional<String> integrity;
  30. Optional<bool> keepalive;
  31. Optional<JS::GCPtr<DOM::AbortSignal>> signal;
  32. Optional<Bindings::RequestDuplex> duplex;
  33. Optional<JS::Value> window;
  34. // https://infra.spec.whatwg.org/#map-is-empty
  35. bool is_empty() const
  36. {
  37. return !(method.has_value()
  38. || headers.has_value()
  39. || body.has_value()
  40. || referrer.has_value()
  41. || referrer_policy.has_value()
  42. || mode.has_value()
  43. || credentials.has_value()
  44. || cache.has_value()
  45. || redirect.has_value()
  46. || integrity.has_value()
  47. || keepalive.has_value()
  48. || signal.has_value()
  49. || duplex.has_value()
  50. || window.has_value());
  51. }
  52. };
  53. // https://fetch.spec.whatwg.org/#request
  54. class Request final
  55. : public Bindings::PlatformObject
  56. , public BodyMixin {
  57. WEB_PLATFORM_OBJECT(Request, Bindings::PlatformObject);
  58. public:
  59. static JS::NonnullGCPtr<Request> create(NonnullRefPtr<Infrastructure::Request>, Headers::Guard, JS::Realm&);
  60. static WebIDL::ExceptionOr<JS::NonnullGCPtr<Request>> construct_impl(JS::Realm&, RequestInfo const& input, RequestInit const& init = {});
  61. virtual ~Request() override;
  62. // ^BodyMixin
  63. virtual Optional<MimeSniff::MimeType> mime_type_impl() const override;
  64. virtual Optional<Infrastructure::Body&> body_impl() override;
  65. virtual Optional<Infrastructure::Body const&> body_impl() const override;
  66. [[nodiscard]] NonnullRefPtr<Infrastructure::Request> request() const { return m_request; }
  67. // JS API functions
  68. [[nodiscard]] String method() const;
  69. [[nodiscard]] String url() const;
  70. [[nodiscard]] JS::NonnullGCPtr<Headers> headers() const;
  71. [[nodiscard]] Bindings::RequestDestination destination() const;
  72. [[nodiscard]] String referrer() const;
  73. [[nodiscard]] Bindings::ReferrerPolicy referrer_policy() const;
  74. [[nodiscard]] Bindings::RequestMode mode() const;
  75. [[nodiscard]] Bindings::RequestCredentials credentials() const;
  76. [[nodiscard]] Bindings::RequestCache cache() const;
  77. [[nodiscard]] Bindings::RequestRedirect redirect() const;
  78. [[nodiscard]] String integrity() const;
  79. [[nodiscard]] bool keepalive() const;
  80. [[nodiscard]] bool is_reload_navigation() const;
  81. [[nodiscard]] bool is_history_navigation() const;
  82. [[nodiscard]] JS::NonnullGCPtr<DOM::AbortSignal> signal() const;
  83. [[nodiscard]] WebIDL::ExceptionOr<JS::NonnullGCPtr<Request>> clone() const;
  84. private:
  85. Request(JS::Realm&, NonnullRefPtr<Infrastructure::Request>);
  86. virtual void visit_edges(Cell::Visitor&) override;
  87. // https://fetch.spec.whatwg.org/#concept-request-request
  88. // A Request object has an associated request (a request).
  89. NonnullRefPtr<Infrastructure::Request> m_request;
  90. // https://fetch.spec.whatwg.org/#request-headers
  91. // A Request object also has an associated headers (null or a Headers object), initially null.
  92. JS::GCPtr<Headers> m_headers;
  93. // https://fetch.spec.whatwg.org/#request-signal
  94. // A Request object has an associated signal (null or an AbortSignal object), initially null.
  95. JS::GCPtr<DOM::AbortSignal> m_signal;
  96. };
  97. }