CrossOriginOpenerPolicy.h 1.1 KB

123456789101112131415161718192021222324252627282930313233343536
  1. /*
  2. * Copyright (c) 2022, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/String.h>
  8. namespace Web::HTML {
  9. // https://html.spec.whatwg.org/multipage/origin.html#cross-origin-opener-policy-value
  10. enum class CrossOriginOpenerPolicyValue {
  11. UnsafeNone,
  12. SameOriginAllowPopups,
  13. SameOrigin,
  14. SameOriginPlusCOEP,
  15. };
  16. // https://html.spec.whatwg.org/multipage/origin.html#cross-origin-opener-policy
  17. struct CrossOriginOpenerPolicy {
  18. // A value, which is a cross-origin opener policy value, initially "unsafe-none".
  19. CrossOriginOpenerPolicyValue value { CrossOriginOpenerPolicyValue::UnsafeNone };
  20. // A reporting endpoint, which is string or null, initially null.
  21. Optional<String> reporting_endpoint;
  22. // A report-only value, which is a cross-origin opener policy value, initially "unsafe-none".
  23. CrossOriginOpenerPolicyValue report_only_value { CrossOriginOpenerPolicyValue::UnsafeNone };
  24. // A report-only reporting endpoint, which is a string or null, initially null.
  25. Optional<String> report_only_reporting_endpoint;
  26. };
  27. }