FetchRecord.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /*
  2. * Copyright (c) 2024, Mohamed amine Bounya <mobounya@gmail.com>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <LibWeb/Fetch/Infrastructure/FetchController.h>
  8. #include <LibWeb/Fetch/Infrastructure/HTTP/Requests.h>
  9. namespace Web::Fetch::Infrastructure {
  10. // https://fetch.spec.whatwg.org/#concept-fetch-record
  11. class FetchRecord : public JS::Cell {
  12. JS_CELL(FetchRecord, JS::Cell);
  13. JS_DECLARE_ALLOCATOR(FetchRecord);
  14. public:
  15. [[nodiscard]] static JS::NonnullGCPtr<FetchRecord> create(JS::VM&, JS::NonnullGCPtr<Infrastructure::Request>);
  16. [[nodiscard]] static JS::NonnullGCPtr<FetchRecord> create(JS::VM&, JS::NonnullGCPtr<Infrastructure::Request>, JS::GCPtr<FetchController>);
  17. [[nodiscard]] JS::NonnullGCPtr<Infrastructure::Request> request() const { return m_request; }
  18. void set_request(JS::NonnullGCPtr<Infrastructure::Request> request) { m_request = request; }
  19. [[nodiscard]] JS::GCPtr<FetchController> fetch_controller() const { return m_fetch_controller; }
  20. void set_fetch_controller(JS::GCPtr<FetchController> fetch_controller) { m_fetch_controller = fetch_controller; }
  21. private:
  22. explicit FetchRecord(JS::NonnullGCPtr<Infrastructure::Request>);
  23. FetchRecord(JS::NonnullGCPtr<Infrastructure::Request>, JS::GCPtr<FetchController>);
  24. virtual void visit_edges(Visitor&) override;
  25. // https://fetch.spec.whatwg.org/#concept-request
  26. // A fetch record has an associated request (a request)
  27. JS::NonnullGCPtr<Infrastructure::Request> m_request;
  28. // https://fetch.spec.whatwg.org/#fetch-controller
  29. // A fetch record has an associated controller (a fetch controller or null)
  30. JS::GCPtr<FetchController> m_fetch_controller { nullptr };
  31. };
  32. }