ladybird/Libraries/LibWeb/HTML/Scripting/EnvironmentSettingsSnapshot.h
Luke Wilde cae0ab2139 LibWeb: Make PolicyContainer GC allocated
This is required to store Content Security Policies, as their
Directives are implemented as subclasses with overridden virtual
functions. Thus, they cannot be stored as generic Directive classes, as
it'll lose the ability to call overridden functions when they are
copied.
2025-02-21 12:43:48 +00:00

44 lines
1.5 KiB
C++

/*
* Copyright (c) 2024, Andrew Kaster <akaster@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
#pragma once
#include <LibWeb/HTML/PolicyContainers.h>
#include <LibWeb/HTML/Scripting/Environments.h>
#include <LibWeb/HTML/Scripting/SerializedEnvironmentSettingsObject.h>
namespace Web::HTML {
class EnvironmentSettingsSnapshot final
: public EnvironmentSettingsObject {
GC_CELL(EnvironmentSettingsSnapshot, EnvironmentSettingsObject);
GC_DECLARE_ALLOCATOR(EnvironmentSettingsSnapshot);
public:
EnvironmentSettingsSnapshot(JS::Realm&, NonnullOwnPtr<JS::ExecutionContext>, SerializedEnvironmentSettingsObject const&);
virtual ~EnvironmentSettingsSnapshot() override;
GC::Ptr<DOM::Document> responsible_document() override { return nullptr; }
String api_url_character_encoding() const override { return m_api_url_character_encoding; }
URL::URL api_base_url() const override { return m_url; }
URL::Origin origin() const override { return m_origin; }
GC::Ref<PolicyContainer> policy_container() const override { return m_policy_container; }
CanUseCrossOriginIsolatedAPIs cross_origin_isolated_capability() const override { return CanUseCrossOriginIsolatedAPIs::No; }
double time_origin() const override { return m_time_origin; }
protected:
virtual void visit_edges(Cell::Visitor&) override;
private:
String m_api_url_character_encoding;
URL::URL m_url;
URL::Origin m_origin;
GC::Ref<PolicyContainer> m_policy_container;
double m_time_origin { 0 };
};
}