Reporting.cpp 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. /*
  2. * Copyright (c) 2022, Linus Groh <linusg@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibJS/Runtime/PropertyKey.h>
  7. #include <LibWeb/HTML/BrowsingContext.h>
  8. #include <LibWeb/HTML/CrossOrigin/AbstractOperations.h>
  9. #include <LibWeb/HTML/CrossOrigin/Reporting.h>
  10. namespace Web::HTML {
  11. // https://html.spec.whatwg.org/multipage/origin.html#coop-check-access-report
  12. void check_if_access_between_two_browsing_contexts_should_be_reported(
  13. BrowsingContext const& accessor,
  14. BrowsingContext const* accessed,
  15. JS::PropertyKey const& property_key,
  16. EnvironmentSettingsObject const& environment)
  17. {
  18. // FIXME: Spec bug: https://github.com/whatwg/html/issues/10192
  19. if (!accessed)
  20. return;
  21. // 1. If P is not a cross-origin accessible window property name, then return.
  22. if (!is_cross_origin_accessible_window_property_name(property_key))
  23. return;
  24. // FIXME: 2. If accessor's active document's origin or any of its ancestors' active document's origins are not same origin with accessor's top-level browsing context's active document's origin, or if accessed's active document's origin or any of its ancestors' active document's origins are not same origin with accessed's top-level browsing context's active document's origin, then return.
  25. // NOTE: This avoids leaking information about cross-origin iframes to a top level frame with cross-origin opener policy reporting.
  26. // FIXME: 3. If accessor's top-level browsing context's virtual browsing context group ID is accessed's top-level browsing context's virtual browsing context group ID, then return.
  27. // 4. Let accessorAccessedRelationship be a new accessor-accessed relationship with value none.
  28. auto accessor_accessed_relationship = AccessorAccessedRelationship::None;
  29. // 5. If accessed's top-level browsing context's opener browsing context is accessor or an ancestor of accessor, then set accessorAccessedRelationship to accessor is opener.
  30. if (auto opener = accessed->top_level_browsing_context()->opener_browsing_context(); opener && (opener == &accessor || opener->is_ancestor_of(accessor)))
  31. accessor_accessed_relationship = AccessorAccessedRelationship::AccessorIsOpener;
  32. // 6. If accessor's top-level browsing context's opener browsing context is accessed or an ancestor of accessed, then set accessorAccessedRelationship to accessor is openee.
  33. if (auto opener = accessor.top_level_browsing_context()->opener_browsing_context(); opener && (opener == accessed || opener->is_ancestor_of(*accessed)))
  34. accessor_accessed_relationship = AccessorAccessedRelationship::AccessorIsOpenee;
  35. // FIXME: 7. Queue violation reports for accesses, given accessorAccessedRelationship, accessor's top-level browsing context's active document's cross-origin opener policy, accessed's top-level browsing context's active document's cross-origin opener policy, accessor's active document's URL, accessed's active document's URL, accessor's top-level browsing context's initial URL, accessed's top-level browsing context's initial URL, accessor's active document's origin, accessed's active document's origin, accessor's top-level browsing context's opener origin at creation, accessed's top-level browsing context's opener origin at creation, accessor's top-level browsing context's active document's referrer, accessed's top-level browsing context's active document's referrer, P, and environment.
  36. (void)accessor;
  37. (void)accessed;
  38. (void)environment;
  39. (void)accessor_accessed_relationship;
  40. }
  41. }