/* * Copyright (c) 2024, Luke Wilde * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include namespace Web::ContentSecurityPolicy::Directives { // https://w3c.github.io/webappsec-csp/#directive-frame-src class FrameSourceDirective final : public Directive { GC_CELL(FrameSourceDirective, Directive) GC_DECLARE_ALLOCATOR(FrameSourceDirective); public: virtual ~FrameSourceDirective() = default; virtual Result pre_request_check(GC::Heap&, GC::Ref, GC::Ref) const override; virtual Result post_request_check(GC::Heap&, GC::Ref, GC::Ref, GC::Ref) const override; private: FrameSourceDirective(String name, Vector value); }; }