mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-07-07 17:41:54 +00:00
These form the basis of Content Security Policy. A policy is a collection of directives that are parsed from either the Content-Security-Policy(-Report-Only) HTTP header, or the `<meta>` element. The directives are what restrict the operations can be performed in the current global execution context. For example, "frame-ancestors: none" tells us to prevent the page from being loaded in an embedded context, such as `<iframe>`. You can see it a bit like OpenBSD's pledge() functionality, but for the web platform: https://man.openbsd.org/pledge.2
19 lines
574 B
C++
19 lines
574 B
C++
/*
|
|
* Copyright (c) 2025, Luke Wilde <luke@ladybird.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibJS/Runtime/Realm.h>
|
|
#include <LibWeb/ContentSecurityPolicy/Directives/Directive.h>
|
|
#include <LibWeb/ContentSecurityPolicy/Directives/DirectiveFactory.h>
|
|
|
|
namespace Web::ContentSecurityPolicy::Directives {
|
|
|
|
GC::Ref<Directive> create_directive(JS::Realm& realm, String name, Vector<String> value)
|
|
{
|
|
dbgln("Potential FIXME: Creating unknown Content Security Policy directive: {}", name);
|
|
return realm.create<Directive>(move(name), move(value));
|
|
}
|
|
|
|
}
|